菜鸟笔记
提升您的技术认知

linux下addr2line命令用法-ag真人游戏

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

网站地图