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的时候只初始化了arr0=57,其余的9个位置事实上都是随机的,不一定是什么,但是基本上不太可能是57,因此,当向下进行代码的时候,第一个arr0是57,可以被打印出来,其他的则因为不是57而导致其指针被if语句变成空指针NULL。

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

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

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

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

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

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

相关推荐
陈随易1 小时前
VSCode的Copilot扩展支持接入DeepSeek,Kimi了!
前端·后端·程序员
我不是外星人3 小时前
有了 Harness Engineering ,真的还需要研发工程师吗?
前端·后端·ai编程
candyTong3 小时前
RTK 技术原理:一次典型会话里,80% 上下文是怎么省下来的
javascript·后端·架构
Rust研习社5 小时前
组合真的优于继承吗?为什么 Rust 和 Go 都拥抱组合舍弃继承?
后端·rust·编程语言
IT_陈寒5 小时前
JavaScript的闭包把我坑惨了,说好的内存会自动回收呢?
前端·人工智能·后端
CaffeinePro6 小时前
Pydantic深度使用:数据校验、枚举、ORM映射
后端·fastapi
Chenyiax7 小时前
从 Chat 到 Responses:OpenAI API 抽象为什么变了?
后端
MariaH7 小时前
Koa和Express的区别
后端
MariaH7 小时前
Koa框架的使用
后端
Jack208 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法