Debug的几种常见方法

本文深入讲解了三种软件调试方法:gdb命令行模式调试、使用printf进行日志调试及断言调试。通过具体实例展示了如何利用__FUNCTION__、__LINE__等预处理宏配合printf定位BUG,以及如何运用assert()函数预防明显错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、gdb调试

​ (命令行模式调试,略)

2、日志调试(printf debug)

__FUNCTION__: 在源代码中插入当前函数名;
__LINE__:    在源代码中插入当前源代码行号;
__FILE__:    在源文件中插入当前源文件名;
__DATE__:    在源文件中插入当前的编译日期;
__TIME__:    在源文件中插入当前编译时间;
__STDC__:    当要求程序严格遵循ANSI C标准时该标识被赋值为1;

用以上 宏 配合 printf 进行调试

​ 定义一个 debug 输出的函数模板

#define Debug()    \
    printf("Bug in function: %s (file: %s), @line: %d. It is compiled on %s  %s, %s ANSI C standard.\n", __FUNCTION__, __FILE__, __LINE__, __TIME__, __DATE__, __STDC__? "with" : "without");

​ 例:觉得可能对某函数因为参数指针 p 是NULL 而使得程序崩溃

if (!p) {
    Debug();
}

​ 如果真的是因为p是NULL造成的问题,程序退出前会输出BUG在源代码的位置,方便追踪。

3、断言调试

	#include <assert.h>
	void assert( int expression );

​ 如果assert()里面内容为假,则之后的命令永远不会执行。(用以避免显而易见的错误)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值