总结
- 断言,是宏,而非函数
- 忽略断言,在代码开头加上:
#define NDEBUG
1、第一个断言案例
断言,是宏,而非函数。assert 宏的原型定义在 (C)、(C++)中,其作用是如果它的条件返回错误,则终止程序执行。可以通过定义 NDEBUG 来关闭 assert,但是需要在源代码的开头,include 之前。
#include <stdio.h>
#include <assert.h>
int main()
{
int x = 7;
/* 中间的一些大代码假设x意外地变成了9 */
x = 9;
// 程序员假设x在其余代码中为7
assert(x==7);
/* 其余代码 */
return 0;
}
//输出
Assertion failed!
Program: E:\CLionProjects\HelloWorld\cmake-build-debug\HelloWorld.exe
File: E:\CLionProjects\HelloWorld\main.cpp, Line 14
Expression: x==7
可以看到输出会把源码文件,行号错误位置,提示出来!
2、断言与正常错误处理
断言主要用于检查逻辑上不可能的情况。例如,它们可用于检查代码在开始运行之前所期望的状态,或者在运行完成后检查状态。与正常的错误处理不同,断言通常在运行时被禁用。
忽略断言,在代码开头加上:
#define NDEBUG // 加上这行,则 assert 不可用
示例如下:
# define NDEBUG // 忽略断言
#include<assert.h>
int main(){
int x=7;
assert(x==5);
return 0;
}
本文详细介绍了断言在C/C++中的使用,包括其作为宏而非函数的特性,如何通过预处理器指令定义NDEBUG来禁用断言,以及断言与正常错误处理的区别。断言主要用于检查逻辑上不可能发生的情况,而错误处理则用于处理运行时可能出现的异常。
1218

被折叠的 条评论
为什么被折叠?



