addr2line可将崩溃地址转为源码位置,需编译时加-g保留调试信息,用-e指定文件、-f显示函数名、-C解构C++符号,如addr2line -e myapp -f -C 0x4005f6得main.c:25。

当Linux程序崩溃时,核心转储(core dump)或日志中常会输出函数调用栈的内存地址。这些地址本身难以阅读,但通过 addr2line 工具,可以将地址转换为具体的源代码文件名和行号,快速定位问题位置。
要使用 addr2line 正确解析地址,编译程序时必须加入调试符号:
如果没有调试信息,addr2line 无法映射到源码行。
常见方式包括:
假设你得到一个地址 0x4005f6,且可执行文件名为 myapp。
基本命令格式:
addr2line -e myapp -f -C 0x4005f6参数说明:
输出示例:
main表示该地址位于 main 函数,对应 main.c 第 25 行。
若需解析多个地址,可在命令末尾连续写入:
addr2line -e myapp -f -C 0x4005f6 0x4006a0 0x400712或通过管道输入:
echo "0x4005f6" | addr2line -e myapp -f -C适合脚本自动化处理堆栈地址列表。
基本上就这些。只要保留调试符号并正确获取地址,addr2line 是快速定位崩溃源头的有效手段。不复杂但容易忽略细节,比如忘记 -f 或未编译 -g。
以上就是Linux如何使用addr2line定位崩溃行号_Linux符号解析技巧的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号