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函数中