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