Android中使用addr2line来分析出错信息

在Ubuntu12.04系统上,当Android 5.0设备出现错误时,可以使用addr2line工具从堆栈报错信息中定位问题。确保设备上的库与编译系统的版本匹配,然后在Android eng版本的symbols目录下查找对应的库。通过addr2line,可以确定错误发生的文件和行号,从而有效定位和解决bug。此外,还介绍了一种通过抛出并捕获异常来打印调用栈的方法。
摘要由CSDN通过智能技术生成

系统:Ubuntu12.04

手机系统:Android5.0

在Android的开发过程中有会有很多的bug,利用工具可以很好的帮忙我们来分析问题,特别是一些系统报错的信息中会打印出堆栈,我们可以根据这个堆栈报错信息定位是哪个文件哪行代码出的错。下面就把我使用addr2line的过程记录下来

首先是在电脑上编译出一个eng版本,烧录到手机,在测试或调试的过程中出错了,查看出错信息如下:

01-23 11:45:38.782 D/AEE/AED (10995): coredump_socket_create: 10905
01-23 11:45:38.783 I/AEE/AED (10995): $** *** *** *** *** *** *** *** Exception *** *** *** *** *** *** *** **$
01-23 11:45:38.783 I/AEE/AED (10995): Build Info: 'L0:ALPS.L0.MP6.V3_GIONEE6752.LWT.L:MT6752:S01,GiONEE/GN9006/GN9006:5.0/LRX21M/1421905945:eng/release-keys'
01-23 11:45:38.784 I/AEE/AED (10995): Flavor Info: 'None'
01-23 11:45:38.784 I/AEE/AED (10995): Exception Log Time:[Fri Jan 23 11:45:38 CST 2015] [65998.900000]
01-23 11:45:38.784 I/AEE/AED (10995): 
01-23 11:45:38.785 I/AEE/AED (10995): Exception Class: Native (NE)
01-23 11:45:38.785 I/AEE/AED (10995): Exception
内核可以使用addr2line工具来进行调试。这个工具可以将地址转换为对应的源代码行号。当我们在内核遇到崩溃或错误时,可以使用addr2line来找到代码出问题的位置。 使用addr2line的步骤如下: 1. 首先,需要编译内核时打开CONFIG_DEBUG_INFO选项。这样编译出的内核会包含调试符号信息。 2. 在发生错误或崩溃的设备上,获取对应的内核转储文件(vmlinux)。如果没有vmlinux文件,可以使用相同版本的内核源代码重新编译内核。 3. 在命令行执行addr2line命令,将错误的地址作为参数传递给它。比如:addr2line -e vmlinux 0xaddress 这将会返回对应地址的源代码文件和行号信息。 通过这个方式,我们可以根据地址找到对应的源代码行号,从而更好地理解和调试内核的问题。 [2 [3123 #### 引用[.reference_title] - *1* [Linux使用addr2line工具定位内核崩溃(oops)代码位置](https://blog.csdn.net/weixin_42262944/article/details/120235491)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *2* *3* [linux内核调试技巧之addr2line](https://blog.csdn.net/weixin_36300275/article/details/116649108)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值