ASSERT()这个宏到底是干什么的?看很多别人写的C/C++代码经常用这个宏?到底有什么用?我去掉这些代码,好像程序照样也能运行啊,为什么还要写这个呢?有大佬帮忙回答吗?

上传的附件
你的回答被采纳后将获得: 8点积分 (将会扣除手续费1点积分。)

keyboard_arrow_left上一篇 : 如何避免头文件被重复包含? malloc/free与new/delete有什么区别? : 下一篇keyboard_arrow_right

3个回答

Foooooooood
2019-01-08 08:49:46

使用断言

assert()宏是用于保证满足某个特定条件,用法是:

  1. assert(表达式);

如果表达式的值为假,整个程序将退出,并输出一条错误信息。如果表达式的值为真则继续执行后面的语句。

使用这个宏前需要包含头文件assert.h,例如

  1. #include <stdio.h>
  2. #include <assert.h>
  3. void main()
  4. {
  5. float a,b;
  6. scan("%f %f",&a,&b);
  7. assert(b!=0);
  8. printf("%f\n",a/b);
  9. }

以上的程序要计算A/B的值,因此要求b!=0,所以在程序中使用了assert()用于确保b!=0,如果b==0,则程序会退出。

不说8163
2019-01-14 15:31:08

对于初学者,可以直接无视ASSERT(),这些是调试用的代码,本身对代码功能无任何影响。

Resurgam
2019-01-22 09:36:08

你可以直接理解成一个 if 判断语句,满足判断条件的话,就直接提示并退出程序

精彩评论

  • [80x86汇编]说说你理解的栈是什么?
    栈就是一段特殊内存,什么是栈呢?举个例子,一个只有上面打开的盒子,现在有三本书离散数学、c语言、汇编语言,需要将这三本书一本一本的放进去,先将离散数学放进去,然后c语言,接着汇编语言,现在又需要将三本书拿出去,只能先拿汇编语言,再拿c语言接着再拿离散数学,栈就是这样的特点,后进先出。 栈的大小怎么确认呢?这是靠我们自己决定的,如何确定这段内存为栈,就需要两个寄存器,段寄存器ss和存放偏移地址的寄存器sp,比如我们决定10000-1000f为寄存器那么ss:sp 一开始应该为 1000:0010执行栈有两个指令push,pop,push是入栈执行过程是先sp+2之后在把数据放进去,pop指令是先出栈,先将指令放进栈接着再sp-2,就好像把东西放进去房间一样,需要先开门再把东西放进去,把东西拿出去,需要把东西拿出去再关门,东西就相当于需要操作的数据,开门和关门就相当于sp+2和sp-2。 栈最大为64kb,这和sp的寻址能力有关,比如 10000-1ffff 为栈,那么 ss:sp 一开始应该指向那里呢?按照之前的算法sp应该为ffff+1 = 10000但是sp只能储存4个字节所以sp = 0,当栈满了之后sp还是为0,这个时候再次入栈0-2 = 0xfffffffe ,所以sp = fffe,之后再次入栈的话就会将原数据给覆盖掉,所以要尽量避免这种情况。
    2019-01-24 13:47:03 thumb_up( 6 )
  • 堆和栈有什么区别???
    栈 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等 栈是向低地址扩展的数据结构,是一块连续的内存的区域。是栈顶的地址和栈的最大容量是系统预先规定好的,栈的大小是2M(也有的说是1M,总之是一个编译时就确定的常数 ) 堆 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 堆是向高地址扩展的数据结构,是不连续的内存区域。这是由于系统是用链表来存储的空闲内存地址的,自然是不连续的,而链表的遍历方向是由低地址向高地址。堆的大小受限于计算机系统中有效的虚拟内存
    2019-01-08 08:47:05 thumb_up( 6 )
  • 大家是怎么开发游戏的啊?
    加油吧,你是怎么学会编程的,就怎么去学开发游戏!从0到1是最难的,从1到N相对来说比较容易
    2019-04-18 09:06:03 thumb_up( 2 )
eject