首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >手把手教你用 addr2line 去 debug

手把手教你用 addr2line 去 debug

作者头像
Jasonangel
发布2022-04-07 20:10:59
发布2022-04-07 20:10:59
6K0
举报

在 Linux 下写 C/C++ 程序的程序员,时常与 Core Dump 相见。在内存越界访问,收到不能处理的信号,除零等错误出现时,我们精心或不精心写就的程序就直接一命呜呼了,Core Dump 是 Linux 仁慈地留下的程序的尸体,帮助程序员们解决了一个又一个问题。

有时配置不给力,Linux 直接毁尸灭迹,没有了 Core 文件;又有时,刚好磁盘空间不足,Core文件写不下了。没有 Core 文件的时候,如何知道程序在什么地方出错了呢?addr2line 就在这时派上用场。

这是一个示例程序,func 函数返回参数 a 除以参数 b 的结果。这里使用 0 作为除数,结果就是程序因为除以 0 导致错误,直接中断了。

test.c

代码语言:javascript
复制
#include <stdio.h>
 
int func(int a, int b)
{
  return a / b;
}
 
int main()
{
  int x = 10;
  int y = 0;
  printf("%d / %d = %d\n", x, y, func(x, y));
  return 0;
}

编译:-o 指定输出文件名,-g 会有调试信息。

代码语言:javascript
复制
gcc -o test -g test.c

执行

代码语言:javascript
复制
./test

提示执行错误

输入 dmesg 命令,查看 log,提示如下:

代码语言:javascript
复制
traps: test[2184] trap divide error ip:400534 sp:7ffee5779a90 error:0 in test[400000+1000]

ip 字段后面的数字就是 test 程序出错时所程序执行的位置。使用 addr2line 就可以将 400534 地址转换出对应的文件及行数

可知,程序在执行到 test.c 文件第五行的时候,执行出错,我们检查第五行代码。

代码语言:javascript
复制
return a / b;

这里除 0 肯定是不行的,addr2line 帮助我们找到了错误位置。

addr2line 用法

-a --addresses:在函数名、文件和行号信息之前,显示地址,以十六进制形式。

-b --target=:指定目标文件的格式为bfdname。

-e --exe=:指定需要转换地址的可执行文件名。

-i --inlines :如果需要转换的地址是一个内联函数,则输出的信息包括其最近范围内的一个非内联函数的信息。

-j --section=:给出的地址代表指定section的偏移,而非绝对地址。

-p --pretty-print:使得该函数的输出信息更加人性化:每一个地址的信息占一行。

-s --basenames:仅仅显示每个文件名的基址(即不显示文件的具体路径,只显示文件名)。

-f --functions:在显示文件名、行号输出信息的同时显示函数名信息。

-C --demangle[=style]:将低级别的符号名解码为用户级别的名字。

-h --help:输出帮助信息。

-v --version:输出版本号。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-02-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 嵌入式Linux系统开发 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • addr2line 用法
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档