C语言小撰特殊篇-assert断言函数

assert()函数是个比较特殊的函数,其内容不多,对于用户来说也没什么很大的意义,然而对于程序员调试过程则非常关键。

今既已兴起思维此物之心念,遂作简洁文章而解释:

首先,要使用assert函数必须要引用头文件assert.h,该头文件是否包含其他函数暂时未知,似乎只包含这一个函数。下面展示一个使用了该函数的代码:

cpp 复制代码
#include<assert.h>
#include<stdio.h>
int main()
{
	int arr[10] = { 57 };
	int* pa = arr;
	while (1) {
		if (*pa != 57) {
			pa = NULL;
		}
		else {
			printf("%d\n", *pa);
		}
		assert(pa!=NULL);
		pa += 1;
	}

	return 0;
}

在这里,我初始化数组arr的时候只初始化了arr[0]=57,其余的9个位置事实上都是随机的,不一定是什么,但是基本上不太可能是57,因此,当向下进行代码的时候,第一个arr[0]是57,可以被打印出来,其他的则因为不是57而导致其指针被if语句变成空指针NULL。

这里必须提示一点我之前写指针部分没有提到的内容,这种将指针设置为NULL的方法是一种固定用法,这个时候指针arr事实上就等于0,通常指针如果没有初始化也没有指向一个正常的变量地址的话,它就大概率是一个------野指针。而这种设置为NULL的方法能有效防止野指针对我们的破坏,以防止它可能的输出奇怪东西的情况。

我们说回这个代码,这个代码因为被设置为空指针NULL而导致assert断言的情况"pa!=NULL"断言失败,这个时候程序会直接停止运行并且无法继续进行下面的语句,而弹出终端报错。

它不但会弹出终端,而且会直接将详细信息提示出来,比如第几行代码断言失败之类的:

由此运行结果可以看出,断言失败的地方在这个文件的第846行。

对于程序员来说,这个功能有助于我们定位代码错误的位置,当我们觉得它没有必要再用但是又很难一下子全部删掉的时候,可以在最上面用宏定义加一句#define NDEBUG,就解决了assert终止程序的效果。只不过应当注意的是,程序这时候仍然会运行到这里,不满足assert条件的时候停下,只不过不会报错,也不打印错误信息了。

在普通用户用的release版本里这个功能通常是被默认禁用的,以提高程序运行的效率,防止突然冒出个东西烦你。

相关推荐
Memory_荒年5 分钟前
ReentrantLock 线程安全揭秘:从“锁”到“重入”的魔法
java·后端·源码
Leo8996 分钟前
go 从零单排之 切片 风云再起
后端
不羁到7 分钟前
【全平台适用】OpenClaw 进阶教程:Docker 隔离运行 + 浏览器联网 + 飞书流式输出
后端
凌览15 分钟前
尤雨溪新公司官宣!Vite+ 正式开源,前端圈要变天了?
前端·javascript·后端
We་ct23 分钟前
LeetCode 22. 括号生成:DFS回溯解法详解
前端·数据结构·算法·leetcode·typescript·深度优先·回溯
zuoerjinshu23 分钟前
【spring专题】编译spring5.3源码
java·后端·spring
JavaGuide27 分钟前
鹅厂面试:SELECT * 一定导致索引失效?常见索引失效场景有哪些?
java·数据库·后端·mysql·大厂面试
mit6.82431 分钟前
tabbi风波|开源协议
算法
是梦终空11632 分钟前
C++中的职责链模式变体
开发语言·c++·算法