在linux下程序崩溃后,一般都会有coredump,但是这个coredump有时候会被截断(尽管已经设置了ulimit -c unlimited也会),导致没法用gdb查看问题所在。
只好想办法在程序崩溃时自己记录下堆栈信息。
思路是:
1.注册信号处理函数,处理所有默认行为为终止程序的信号。
2.用backtrace得到发生问题的线程的堆栈调用地址列表。
3.用backtrace_symbols得到每个地址对应的函数名和偏移量.
4.用addr2line 功能得到偏移量对应的代码文件名和行数(需要在编译的时候设置-g -rdynamic),并将其输出重定位到文件中。
由于addr2line是一个程序名而不是可供c++调用的函数,所以需要重定位cout。
本文介绍了一种在Linux环境下,当程序崩溃时手动记录堆栈信息的方法,包括注册信号处理函数、使用backtrace获取堆栈调用地址列表、利用backtrace_symbols获取函数名和偏移量,并通过addr2line获取代码文件名和行数。
3万+

被折叠的 条评论
为什么被折叠?



