我相信每个程序员年轻的时候,在运行某程序,当屏幕弹出“Segmentation fault”时,你会变得非常焦虑,因为你不知道代码哪里跑挂了,初级程序员常常使用printf函数在怀疑点一个个的加打印去定位问题出在哪里了。
如果你熟悉gdb,你可能会使用gdb去运行这个程序,然后异常后执行backtrace(简写bt)命令打印异常调用栈。
但是gdb并不是万能的,例如程序运行一段时间概率出现“Segmentation fault”的问题,gdb就派不上用场了,我们期望故障复现后,立马能把异常调用栈打印出来。
我们可以利用linux消息机制,例如给0地址赋值会触发段错误,系统会收到SIGSEGV消息,我们给消息注册回调函数,如下部分代码实现这一需求。
下面我们可以在回调函数backtrace_handler中实现异常调用栈的打印。
常规的实现方式是利用backtrace和backtrace_symbols函数就可以实现异常调用栈的打印了,如下部分代码实现这一需求。