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

相关推荐
焗猪扒饭4 小时前
redis stream用作消息队列极速入门
redis·后端·go
树獭非懒5 小时前
AI大模型小白手册|Embedding 与向量数据库
后端·python·llm
IT_陈寒7 小时前
SpringBoot实战:5个让你的API性能翻倍的隐藏技巧
前端·人工智能·后端
梦想很大很大8 小时前
拒绝“盲猜式”调优:在 Go Gin 项目中落地 OpenTelemetry 链路追踪
运维·后端·go
唐叔在学习8 小时前
就算没有服务器,我照样能够同步数据
后端·python·程序员
用户68545375977699 小时前
同步成本换并行度:多线程、协程、分片、MapReduce 怎么选才不踩坑
后端
javaTodo9 小时前
Claude Code 记忆机制详解:从 CLAUDE.md 到 Auto Memory,六层体系全拆解
后端
LSTM9710 小时前
使用 C# 和 Spire.PDF 从 HTML 模板生成 PDF 的实用指南
后端