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版本里这个功能通常是被默认禁用的,以提高程序运行的效率,防止突然冒出个东西烦你。

相关推荐
oak隔壁找我3 小时前
MySQL中 SHOW FULL PROCESSLIST` 输出中 `State` 列的所有可能值
后端
上进小菜猪4 小时前
基于 YOLOv8 的面向文档智能处理的表格区域检测系统 [目标检测完整源码]
后端
oak隔壁找我4 小时前
JVM常用调优参数
java·后端
IT_陈寒7 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
晨星shine8 小时前
GC、Dispose、Unmanaged Resource 和 Managed Resource
后端·c#
蝎子莱莱爱打怪8 小时前
OpenClaw 从零配置指南:接入飞书 + 常用命令 + 原理图解
java·后端·ai编程
倚栏听风雨9 小时前
【ES避坑指南】明明存的是 "CodingAddress",为什么 term 查询死活查不到?彻底搞懂 text 和 keyword
后端
程序员爱钓鱼9 小时前
Go 操作 Windows COM 自动化实战:深入解析 go-ole
后端·go·排序算法
回家路上绕了弯9 小时前
深入解析Agent Subagent架构:原理、协同逻辑与实战落地指南
分布式·后端
子玖9 小时前
实现微信扫码注册登录-基于参数二维码
后端·微信·go