Linux下addr2line命令用法
Posted fengbingchun
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Linux下addr2line命令用法相关的知识,希望对你有一定的参考价值。
Linux下addr2line命令用于将程序指令地址转换为所对应的函数名、以及函数所在的源文件名和行号。当含有调试信息(-g)的执行程序出现crash时(core dumped),可使用addr2line命令快速定位出错的位置。
如果无法确定文件名或函数名,addr2line将在它们的位置打印两个问号;如果无法确定行号,addr2line将打印0或一个问号。
参数说明:
(1).-a:在函数名、文件名和行号信息之前,以十六进制形式显示地址。
(2).-b:指定目标文件的格式为bfdname。
(3).-C:将低级别的符号名解码为用户级别的名字。
(4).-e:指定需要转换地址的可执行文件名,默认文件是a.out。
(5).-f:在显示文件名、行号信息的同时显示函数名。
(6).-s:仅显示每个文件名(the base of each file name)去除目录名。
(7).-i:如果需要转换的地址是一个内联函数,则还将打印返回第一个非内联函数的信息。
(8).-j:读取指定section的偏移而不是绝对地址。
(9).-p:使打印更加人性化:每个地址(location)的信息都打印在一行上。
(10).-r:启用或禁用递归量限制。
(11).--help:打印帮助信息。
(12).--version:打印版本号。
dmesg命令:全称为display message,用来显示Linux内核环形缓冲区信息。
测试代码main.cpp如下:
#include <stdio.h>
int divide(int a, int b)
{
return a/b;
}
int main()
{
fprintf(stdout, "input value\\n");
int a = 3, b = 0;
int div = divide(a, b);
fprintf(stdout, "div value: %d\\n", div);
return 0;
}
在终端输入以下命令:注意不要忘记-g,否则在使用addr2line命令时无法显示文件名和行号
g++ -g main.cpp -o main
执行main,输出结果如下:
通过dmesg命令查看系统日志的错误信息,结果如下:其中ip字段后面的数字4005c4就是main程序出错时所执行的位置
通过addr2line命令将地址4005c4转换定位到代码中出错的位置,命令及执行结果如下:可见crash的地方在main.cpp文件的第5行,在divide函数中
以上是关于Linux下addr2line命令用法的主要内容,如果未能解决你的问题,请参考以下文章
如何在没有core文件的情况下用dmesg+addr2line定位段错误
如何在没有core文件的情况下用dmesg+addr2line定位段错误
Android NDK 开发NDK C/C++ 代码崩溃调试 - Tombstone 报错信息日志文件分析 ( 使用 addr2line 命令行工具查找动态库中的报错代码位置 )
Android NDK 开发NDK C/C++ 代码崩溃调试 - Tombstone 报错信息日志文件分析 ( 使用 addr2line 命令行工具查找动态库中的报错代码位置 )
我的Android进阶之旅如何在Android Studio开发NDK的时候,通过addr2line来定位出错代码的位置
我的Android进阶之旅如何在Android Studio开发NDK的时候,通过addr2line来定位出错代码的位置