linux下程序崩溃后记录调用堆栈.以便查找问题

 在linux下程序崩溃后,一般都会有coredump,但是这个coredump有时候会被截断(尽管已经设置了ulimit -c unlimited也会),导致没法用gdb查看问题所在。

只好想办法在程序崩溃时自己记录下堆栈信息。

思路是:

1.注册信号处理函数,处理所有默认行为为终止程序的信号。

2.用backtrace得到发生问题的线程的堆栈调用地址列表。

3.用backtrace_symbols得到每个地址对应的函数名和偏移量.

4.用addr2line 功能得到偏移量对应的代码文件名和行数(需要在编译的时候设置-g -rdynamic),并将其输出重定位到文件中。

由于addr2line是一个程序名而不是可供c++调用的函数,所以需要重定位cout。

 

展开阅读全文

没有更多推荐了,返回首页