Linux下addr2line命令用法

x33g5p2x  于2021-11-11 转载在 Linux  
字(1.0k)|赞(0)|评价(0)|浏览(979)

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

相关文章