linux下c常用debug(code UT,coredump,网络)

本文介绍了一种通过使用gdb和CoreDump文件来迅速定位程序运行崩溃错误的方法,该方法相较于传统调试手段更为高效。文章详细解释了assert和perror的区别,并提供了在debug过程中排查问题的具体步骤,包括如何使用gcore命令生成core文件,以及如何通过strings命令检查core文件中的特定字符串。此外,还提到了gcov代码覆盖率测试、内存管理、Debugfs文件系统等其他调试工具和技术。

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

a)通过阅读代码;
b)通过在代码中设置一些打印语句(插旗子);
c)通过使用gdb设置断点来跟踪程序的运行。但是这些方法对于调试程序运行崩溃这样类似的错误,定位都不够迅速,如果程序代码很多的话,显然前面的方法有很多缺陷.在后面,我们来看看另外一种可以定位错误的方法:
d)使用gdb结合Core Dump文件来迅速定位到这个错误.这个方法,如果程序运行崩溃,那么可以迅速找到导致程序崩溃的原因。

1 要么使用debugger产生条件断点,要么在代码里加测试代码打出log(或者是core file)
asser ,perror,errno, strerrno
assert 和perror 有什么区别。
asset就是为了产生coredump。用coredump调查问题。是一个判断。assert失败,通过abort  产生coredump.
perror是一个输出,printf 一个errno。
==========
 2   debug run product -strings and gcore
在debug COOLsdcs的时候,不能确认是不是自己的private log,for example: print "line1000";
是不是被加载。
1) 可以采用strings COOLsdcs |print felixzh1
2) 可以使用gcore产生core,再通过strings看看core里面有没有你那个字符串。
gcore solaris和linux通用。如何用gcore呢。
下面解决方法引自网络:
问题:当调试一个程序的时候,理想状态是不重启应用程序就获取core文件。
解决:gcore命令可以使用下面步骤来获取core文件:
1). 确认gdb软件包已经被正确安装。
2). 使用调试参数编译程序(例如: gcc中使用"-g"选项),编译后不要去除文件的调试符号信息。
3). 执行应用程序。
4). 执行gcore命令生成指定应用程序的core文件并且保存在当前目录下。
$ gcore pid   (进程号)

3  gcov代码覆盖率测试
4 内存管理:memleak,valgrind
5 Debugfs 文件系统目的是为开发人员提供更多内核数据,方便调试内容

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值