为了能够快速找到发生段错误的地方,记录以下两种方法。
objdump和backtrace的配合使用 :https://www.cnblogs.com/jiangyibo/p/9507555.html
代码:test.c
一、命令addr2line: addr2line -e '可执行文件名' 'dmesg打印的地址'
编译的时候一定要加“-g” 添加调试信息:gcc -g test.c
生成的可执行文件a.out一运行就会报错:Segmentation fault
调用命令dmesg ,可以查看系统启动信息,其中最新的一行信息应该是段错误的描述信息,如下,ip后的地址就是发生段错误的地址。
然后调用命令"addr2line -e a.out 0x8043db"就会打印出发生错误的文件和行号:
二、core dumpe文件:程序崩溃时会保存程序运行时的内存信息
先使用 ulimit -a 查看目前资源限制的设定:
可查看到“core file size”的大小为0,我们设置成 200。
然后再次 gcc -g test.c ,运行可执行文件a.out:
ls可以看到当前目录下生成了“core”文件
然后我们 gdb a.out:
可以看到,一旦我们run了之后,程序就会停在发生段错误的地方。
或者执行 gdb a.out core ,gdb会自动运行并停在发生段错误的地方。
一般调用ulimit -c X 设置的文件大小都是临时有效,如果要设置永久有效,可以修改/etc/security/limits.conf 文件, 找到 * soft core 0,修改为* soft core unlimited保存,这样每次启动时都会去读取这个配置文件。