linux:binutils工具集---addr2line(段错误Segmentation fault 基本检查和tombstone分析)

binutils工具集---addr2line

 addr2line是用来将程序地址转换成其所对应的程序源文件及所对应的代码行,也可以得到所对应的函数。

测试代码:

#include<stdio.h>

void test_fun()
{
	printf("this fun address is %p\n",test_fun);
}

int main()
{
	test_fun();
	return 0;
}

addr2line命令测试

linux@ubuntu:/mnt/hgfs/000myShare/binutils$ gcc -g add2line.c -o test
linux@ubuntu:/mnt/hgfs/000myShare/binutils$ ./test
this fun address is 0x804841d
linux@ubuntu:/mnt/hgfs/000myShare/binutils$ addr2line 0x804841d -f -e test
test_fun
/mnt/hgfs/000myShare/binutils/add2line.c:4
linux@ubuntu:/mnt/hgfs/000myShare/binutils$

再来看看addr2line命令的具体用途,当程序崩溃或者出现段错误则用途就很大了,如下测试代码:

1. 测试代码

#include<stdio.h>

void Segmentation_fault()
{
	int *p = NULL;
	/* 这里会报 Segmentation fault */
	*p = 1;
}

int main()
{
	/* 调用 */
	Segmentation_fault();
	return 0;
}

2.编译:添加 -g -o 选项  生成目标文件 Segmentation_fault

$ gcc Segmentation_fault.c -g -o Segmentation_fault

3.运行目标文件

$ ./gcc Segmentation_fault

发生 Segmentation fault 错误

4. 使用dmesg工具显示内核缓冲区系统控制信息

$ dmesg | tail

[ 1494.867524] eth0: no IPv6 routers present
[ 1542.731607] eth0: no IPv6 routers present
[ 1590.887683] eth0: no IPv6 routers present
[ 1639.009094] eth0: no IPv6 routers present
[ 1849.965047] Segmentation_fault[2787]: segfault at 0 ip 080483c4 sp bfa80fb0 error 6 in Segmentation_fault[8048000+1000]

5.使用addr2line  工具定位 Segmentation fault 具体位置

$ addr2line -e Segmentation_fault 080483c4 -f

./Segmentation_fault.c:7      

这里的 7 就是发生Segmentation fault所在行。

 

还有一些比如安卓调试中会有tombstone分析,这样我们就可以在tombstone文件中根据堆栈指针进行崩溃定位。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值