谷动谷力

 找回密码
 立即注册
查看: 665|回复: 0
打印 上一主题 下一主题
收起左侧

手把手教你用 addr2line 去 debug

[复制链接]
跳转到指定楼层
楼主
发表于 2024-2-27 12:03:41 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
手把手教你用 addr2line 去 debug

在Linux下写C/C++程序的程序员,时常与 Core Dump 相见。在内存越界访问,收到不能处理的信号,除零等错误出现时,我们精心或不精心写就的程序就直接一命呜呼了,Core Dump 是 Linux 仁慈地留下的程序的尸体,帮助程序员们解决了一个又一个问题。
有时配置不给力,Linux 直接毁尸灭迹,没有了 Core 文件;又有时,刚好磁盘空间不足,Core文件写不下了。没有Core文件的时候,如何知道程序在什么地方出错了呢?addr2line 就在这时派上用场。
这是一个示例程序,func函数返回参数a除以参数b的结果。这里使用0作为除数,结果就是程序因为除以0导致错误,直接中断了。
  1. #include <stdio.h>

  2. int func(int a, int b)
  3. {
  4.   return a / b;
  5. }

  6. int main()
  7. {
  8.   int x = 10;
  9.   int y = 0;
  10.   printf("%d / %d = %d\n", x, y, func(x, y));
  11.   return 0;
  12. }
复制代码


编译,-o 指定输出文件名,-g 选项会有调试信息。
  1. gcc -o test -g test.c
复制代码


执行
  1. ./test
复制代码


提示执行错误
输入 dmesg 命令,查看 log,提示如下:
  1. traps: test[2184] trap divide error ip:400534 sp:7ffee5779a90 error:0 in test[400000+1000]
复制代码


ip 字段后面的数字就是 test 程序出错时所程序执行的位置。使用 addr2line 就可以将 400534 地址转换出对应的文件及行数,
可知,程序在执行到 test.c 文件第五行的时候,执行出错,我们检查第五行代码。
  1. 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:输出版本号。

+10
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|深圳市光明谷科技有限公司|光明谷商城|Sunshine Silicon Corpporation ( 粤ICP备14060730号|Sitemap

GMT+8, 2024-5-5 11:54 , Processed in 0.305267 second(s), 42 queries .

Powered by Discuz! X3.2 Licensed

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表