C语言C++中assert的用法
Posted 跟田老师学C++
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言C++中assert的用法相关的知识,希望对你有一定的参考价值。
断言assert原型
void assert(int expression);
assert宏的原型定义在<assert.h>中,其作用是先计算表达式expression的值为假(即为0),那么它就先向stderr打印一条出错信息,然后通过条用abort来终止程序;
使用assert的缺点是,频繁的调用会极大的影响程序的性能,增加额外的开销。
在调试结束后,可以通过在包含#include 的语句之前插入 #define NDEBUG 来禁用assert调用,示例代码如下:
1 #include
2 #define NDEBUG
3 #include
断言assert使用规则
#include <stdio.h>
#include <assert.h>
int main(void)
{
int i;
i = 1;
assert(i++);
printf(“%d
”,i);
return 0;
}
看运行结果,如果给定的i初始值为1,所以其运行结果不会为错,如下图所示
如果将i初始值改成0,那么就会出现如下错误:
上面这个错误是很典型异常,可以考虑用assert排查。
根据提示我们很快就能定位到错误点,就在assert(i++)处;既然assert这么便于定位出错点,在工程中使用它就显得很有必要;但其也有一定的使用规则;
断言语句不会永远被执行,可以屏蔽也可以启用,这就要求assert不管是在屏蔽还是启用状态下都不能对我们本身代码有所影响,这样刚才我们在代码中使用的assert(i++)
就不行,因为如果禁用了assert
,那i++就不能执行;正确的做法应该是:assert(i);i++;
那么我们一般在什么情况下使用断言呢?
主要体现在以下几个方面:
-
前置条件:代码执行前必须具备的特性; -
后置条件:代码执行后必须具备的特性;
断言assert使用规则
当然我们在使用断言的过程中会有一些我们应该注意的事项和养成一些良好的习惯,如:
无法直观的判断哪个条件失败:
assert(nOffset>=0 && nOffset+nSize<=m_nInfomationSize);
只检验一个条件,比较直观:
assert(nOffset >= 0);
assert(nOffset+nSize <= m_nInfomationSize);
例如:
assert(i++ < 100)
不好:这是因为如果出错,比如在执行之前i=100,那么这条语句就不会执行,那么i++这条命令就没有执行。
assert(i < 100)
i++;
正确。
程序一般分为Debug 版本和Release 版本,Debug 版本用于内部调试,Release 版本发行给用户使用。断言assert 是仅在Debug 版本起作用的宏,它用于检查"不应该"发生的情况。
int resetBufferSize(int nNewSize)
{
//功能:改变缓冲区大小,
//参数:nNewSize 缓冲区新长度
//返回值:缓冲区当前长度
//说明:保持原信息内容不变 nNewSize<=0表示清除缓冲区
assert(nNewSize >= 0);
assert(nNewSize <= MAX_BUFFER_SIZE);
...
}
在我们使用C语言/C++做工程项目时,如果我们能在代码中合理的使用assert,能使我们创建更稳定、质量更好且不易于出错的代码;当需要在一个值为FALSE时中断当前操作的话就可以使用断言。
单元测试必须使用断言;另外除了类型检查和单元测试外,断言还提供了一种确定各种特性是否在程序中得到维护的极好的方法。
欢迎一起交流C++开发
请扫描下方二维码加田老师为微信好友
欢迎加入“C++/Qt”知识星球
记得帮我点赞/在看哦
以上是关于C语言C++中assert的用法的主要内容,如果未能解决你的问题,请参考以下文章