博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android 调用堆栈跟踪
阅读量:7145 次
发布时间:2019-06-29

本文共 6470 字,大约阅读时间需要 21 分钟。

 Android开发中,我们也会经常遇到段错误,也就是SIGSEGV(11),这个时候libc的backtrace会打印出对应的堆栈信 息,而你看到的仅仅是一对数字,好像无从查起。

如下面这一从串断错误:

ActivityManager( 
1105): Displayed activity com.android.browser/.BrowserActivity: 
2460 ms (total 
2460 ms)

I/DEBUG   (
13002): *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***

I/DEBUG   (
13002): Build fingerprint: 
'
unknown
'

I/DEBUG   (
13002): pid: 
20363, tid: 
20375  >>> com.android.browser <<<

I/DEBUG   (
13002): signal 
11 (SIGSEGV), fault addr ffc00000

I/DEBUG   (
13002):  r0 059fc2a0  r1 4a3bcef8  r2 e59fc2a0  r3 4a3bcc58

I/DEBUG   (
13002):  r4 4a3bc101  r5 4ebe0a3c  r6 4a3bc120  r7 012fff10

I/DEBUG   (
13002):  r8 500de101  r9 500ee12d  
10 a87dfb20  fp 4ebe58e0

I/DEBUG   (
13002):  ip ffc00000  sp 4ebe0a30  lr 4a3bcc58  pc a862f3a0  cpsr 
00000030

I/DEBUG   (
13002):  d0  
0000001100000011  d1  
0000001100000011

I/DEBUG   (
13002):  d2  
0000001100000011  d3  
0000001100000011

I/DEBUG   (
13002):  d4  
0000001100000011  d5  
0000001100000011

I/DEBUG   (
13002):  d6  
0000001100000011  d7  
4060000000000080

I/DEBUG   (
13002):  d8  41d3d1762e40d70a  d9  41d3d1762e440a3d

I/DEBUG   (
13002):  d10 
0000000000000000  d11 
0000000000000000

I/DEBUG   (
13002):  d12 
0000000000000000  d13 
0000000000000000

I/DEBUG   (
13002):  d14 
0000000000000000  d15 
0000000000000000

I/DEBUG   (
13002):  d16 3ff0000000000000  d17 3ff0000000000000

I/DEBUG   (
13002):  d18 40cd268000000000  d19 3f3b9cc1b0bac000

I/DEBUG   (
13002):  d20 3ff0000000000000  d21 
8000000000000000

I/DEBUG   (
13002):  d22 
0000000000000000  d23 
0000000000000000

I/DEBUG   (
13002):  d24 3ff0000000000000  d25 
0000000000000000

I/DEBUG   (
13002):  d26 
0000000000000000  d27 
0000000000000000

I/DEBUG   (
13002):  d28 
0000000000000000  d29 3ff0000000000000

I/DEBUG   (
13002):  d30 
0000000000000000  d31 3ff0000000000000

I/DEBUG   (
13002):  scr 
60000013

I/DEBUG   (
13002): 

I/DEBUG   (
13002):          #
00  pc 0032f3a0  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
01  pc 003243b0  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
02  pc 003167b2  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
03  pc 0038f2de  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
04  pc 0038f416  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
05  pc 0030d392  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
06  pc 003796e2  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
07  pc 0038e36a  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
08  pc 003189f0  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
09  pc 00377f82  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
10  pc 0037ae0c  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
11  pc 0038e254  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
12  pc 003189f0  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
13  pc 0031cf2c  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
14  pc 0038e52a  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
15  pc 0038c2d0  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
16  pc 0031cf76  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
17  pc 0038e546  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
18  pc 003189f0  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
19  pc 0031ca40  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
20  pc 0038e3be  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
21  pc 0038c2d0  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
22  pc 0031cf76  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
23  pc 0038e546  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
24  pc 0038c2d0  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
25  pc 
00379054  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
26  pc 0031d254  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
27  pc 0030d5d6  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
28  pc 0030d7d2  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
29  pc 0031e354  /system/lib/libwebcore.so

I/DEBUG   (
13002):          #
30  pc 0034ab3c  /system/lib/libwebcore.so

I/DEBUG   (
13002): 

I/DEBUG   (
13002): code around pc:

I/DEBUG   (
13002): a862f380 469e4694 cc04f853 0e04f1a3 510cea4f 

I/DEBUG   (
13002): a862f390 f41c0d09 bf080f00 
44714249 c008f8d1 

I/DEBUG   (
13002): a862f3a0 e000f8dc 0c1ff10e bf0842b8 2d04f853 

I/DEBUG   (
13002): a862f3b0 0d010510 0f00f412 4249bf08 f8c2185a 

I/DEBUG   (
13002): a862f3c0 e006c008 d1042b0c 99019b05 
18426818 

I/DEBUG   (
13002): 

I/DEBUG   (
13002): code around lr:

I/DEBUG   (
13002): 4a3bcc38 e58d0000 e49d0004 e598200b e582002f 

I/DEBUG   (
13002): 4a3bcc48 e52d0004 e3100001 0a000018 e3a03030 

I/DEBUG   (
13002): 4a3bcc58 e59fc2a0 e002100c e59fc29c e151000c 

I/DEBUG   (
13002): 4a3bcc68 0a000012 e59fc294 e002100c e0813003 

I/DEBUG   (
13002): 4a3bcc78 e1a03123 e1c2200c e3530b02 ba000004 

I/DEBUG   (
13002): 

I/DEBUG   (
13002): stack:

I/DEBUG   (
13002):     4ebe09f0  50bfd848  

I/DEBUG   (
13002):     4ebe09f4  50bfd858  

I/DEBUG   (
13002):     4ebe09f8  50bfd834  

I/DEBUG   (
13002):     4ebe09fc  afd19a05  /system/lib/libc.so

I/DEBUG   (
13002):     4ebe0a00  50bd3264  

I/DEBUG   (
13002):     4ebe0a04  a86510ef  /system/lib/libwebcore.so

I/DEBUG   (
13002):     4ebe0a08  
00000004  

I/DEBUG   (
13002):     4ebe0a0c  50bfd854  

I/DEBUG   (
13002):     4ebe0a10  002ece20  [heap]

I/DEBUG   (
13002):     4ebe0a14  4a3ba000  

I/DEBUG   (
13002):     4ebe0a18  4ebe0a3c  

I/DEBUG   (
13002):     4ebe0a1c  4ebe0a3c  

I/DEBUG   (
13002):     4ebe0a20  4a3bc101  

I/DEBUG   (
13002):     4ebe0a24  4ebe0a3c  

I/DEBUG   (
13002):     4ebe0a28  df002777  

I/DEBUG   (
13002):     4ebe0a2c  e3a070ad  

I/DEBUG   (
13002): #
00 4ebe0a30  002ece20  [heap]

I/DEBUG   (
13002):     4ebe0a34  49f627d0  

I/DEBUG   (
13002):     4ebe0a38  a87d63c0  /system/lib/libwebcore.so

I/DEBUG   (
13002):     4ebe0a3c  4a3bd0e7  

I/DEBUG   (
13002):     4ebe0a40  4a3bd0b8  

I/DEBUG   (
13002):     4ebe0a44  4a3bcc58  

I/DEBUG   (
13002):     4ebe0a48  
00000003  

I/DEBUG   (
13002):     4ebe0a4c  
00000000  

I/DEBUG   (
13002):     4ebe0a50  
00001100  

I/DEBUG   (
13002):     4ebe0a54  0000001f  

I/DEBUG   (
13002):     4ebe0a58  
00001074  

I/DEBUG   (
13002):     4ebe0a5c  4ebe0b04  

I/DEBUG   (
13002):     4ebe0a60  a87d63c0  /system/lib/libwebcore.so

I/DEBUG   (
13002):     4ebe0a64  4ebe0acc  

I/DEBUG   (
13002):     4ebe0a68  4a3bc101  

I/DEBUG   (
13002):     4ebe0a6c  a86243b5  /system/lib/libwebcore.so

I/DEBUG   (
13002): #
01 4ebe0a70  4ebe0b38  

I/DEBUG   (
13002):     4ebe0a74  
00000064  

I/DEBUG   (
13002):     4ebe0a78  003f0914  [heap]

I/DEBUG   (
13002):     4ebe0a7c  fffffc00  

I/DEBUG   (
13002):     4ebe0a80  50bfd834  

I/DEBUG   (
13002):     4ebe0a84  a87d63c0  /system/lib/libwebcore.so

I/DEBUG   (
13002):     4ebe0a88  4ebe0b38  

I/DEBUG   (
13002):     4ebe0a8c  4ebe0b04  

I/DEBUG   (
13002):     4ebe0a90  4ebe0acc  

I/DEBUG   (13002):     4ebe0a94  a86167b7  /system/lib/libwebcore.so

 

我们的板子上的lib 经常被strip过了,没有了符号信息。不过我们可以通过编译时候生成的库来获取对应的符号信息。编译器也为我们提供了相应的工具:addr2line 全名为:arm-eabi-addr2line ,可在对应板子源码目录找到。

 

通过上面的断错误分析,位于system/lib/libwebcore.so 这个库出现了断错误,可以将其pull下来正逐行分析。命令为:arm-eabi-addr2line -f -e ~/桌面/libwebcore.so 0038f2de 

 

这种分析法同样适用于使用jni开发的库。 

 
 本文转自 terry_龙 51CTO博客,原文链接:http://blog.51cto.com/terryblog/796583
,如需转载请自行联系原作者
你可能感兴趣的文章
基于Nginx反向代理及负载均衡
查看>>
SAP ALL compile code: SGEN
查看>>
Oracle体系结构之检查点
查看>>
SQL Server 2017 AlwaysOn on Linux 配置和维护(15)
查看>>
以太坊的势与局
查看>>
如何结合使用 Subversion 和 Eclipse
查看>>
ELK 实验(五)配置数据源和仪表盘
查看>>
centos 6.3搭建个人私有云存储owncloud
查看>>
PHP中的浅拷贝和深拷贝
查看>>
利用redis-sentinel+keepalived实现redis高可用
查看>>
CloudStack4.2登录报用户名或密码错误问题解析
查看>>
逻辑备库之ORA-01403解决方法
查看>>
MySQL Replication(复制)基本原理
查看>>
分享Silverlight/WPF/Windows Phone/HTML5一周学习导读(12月5日-12月11日)
查看>>
十年老站吐血迁移实录
查看>>
配置Exchange2010的边缘传输服务器
查看>>
我的家庭私有云计划-7
查看>>
Word中使用正则表达式进行查找和替换
查看>>
Cocos2d-x Eclipse下程序运行产生错误Effect initCheck() returned -1
查看>>
微软MVP社区巡讲
查看>>