在linux下,程序莫名奇妙崩溃,而且不是固定的崩溃,这种情况,你肯定很捉急。这里你可以利用addr2line定位到程序崩溃的地点。首先你先到/var/log/syslog,这里log不一定是这个文件,有可能时间久了,压缩了。然后打开它,你会发现general protection ip:43917e sp:7fa0ca7a3cd0 error:0 in 。 ip 指是编码器的编译后命令address(这个不知是偏移量还是别的,没有深入了解),然后利用addr2line。
addr2line -e test1 43917e
这个-e 指定你运行的程序。然后是奔溃的地址,这样你就可以得到崩溃那句的行数了。
如果你想更直观看到哪一句,就自己加上程序源码,这个自己搜索一下就可以了。
2,你可以用dmesg来查看错误信息

本文介绍如何使用addr2line工具在Linux环境下定位程序崩溃的具体位置。通过解析/var/log/syslog日志文件中的崩溃地址,结合addr2line命令可以找到引发崩溃的代码行。此外,还可以使用dmesg命令来获取更多的错误信息。
2788

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



