Android 调用堆栈跟踪
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开发的库。
转载http://terryblog.blog.51cto.com/1764499/796583
Android 调用堆栈跟踪的更多相关文章
- arm-eabi-addr2line工具跟踪Android调用堆栈
使用arm-eabi-addr2line工具跟踪Android调用堆栈作者:liangshengyang转自:http://www.linuxidc.com/Linux/2011-01/31803.h ...
- Dynamics AX 2012 R2 堆栈跟踪:不能对客户端调用'unchecked'
有一个Custom Service一直在正常使用.今天,Reinhard尝试在JOB中以X++代码Debug Custom Service的Method时,收到以下错误提示: 'unchecked' ...
- Android调用JNI本地方法跟踪目标代码
正如Android调用JNI本地方法经过有点改变章所说跟踪代码是可行的,但是跟踪某些代码会出现anr,点击取消,还是不好运,有提高办法吗?回答是有(gdb还没试过,本文只讨论ida). 下面是我使用 ...
- 异常 Exception 堆栈跟踪 异常捕获 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- Xdebug文档(三)堆栈跟踪
当xdebug激活时,PHP一旦要显示通知.警告或错误时,xdebug 显示堆栈跟踪信息.这个堆栈信息能跟据你的需要来配置显示. Xdebug显示的堆栈跟踪都是以保守数量状态显示信息.因为大量的信息处 ...
- 在 Visual Studio 中调试时映射调用堆栈上的方法
本文转自:https://msdn.microsoft.com/zh-cn/library/dn194476.aspx 1.创建代码图,以便在调试时对调用堆栈进行可视化跟踪. 你可以在图中进行标注以跟 ...
- GDB堆栈跟踪与汇编调试
GDB堆栈跟踪与汇编调试 堆栈跟踪 源代码: 对预先编写的 stack.c 文件进行编译,并且使用 CGDB 进行调试,对堆栈进行跟踪,了解该代码堆栈是如何变化的. 在 CGDB 中,先设置 main ...
- [转]如何利用ndk-stack工具查看so库的调用堆栈【代码示例】?
如何利用ndk-stack工具查看so库的调用堆栈[代码示例]? http://hi.baidu.com/subo4110/item/d00395b3bf63e4432bebe36d Step1:An ...
- 使用StackTrace堆栈跟踪记录详细日志(可获取行号)
上一篇我们提到使用.NET自带的TraceSource实现简单的日志,具体请看<轻松背后的N+疲惫——系统日志>,这一篇注意想讲的是日志的详细记录,包含请求开始到结束的过程中调用的方法链以 ...
随机推荐
- JavaScript中逻辑运算符
一.JavaScript“逻辑”运算符 很多学习 JavaScript的人,容易被 JavaScript 的逻辑运算符的运算规则搞晕.为什么呢?因为JavaScript的逻辑运算符和其他语言(比如:j ...
- 浅谈CSRF攻击方式(转)
引自:http://www.cnblogs.com/hyddd/一.CSRF是什么? CSRF(Cross-site request forgery),中文名称:跨站请求伪造,也被称为:one cli ...
- word2vector 理解入门
1.什么是word2vector? 我们先来看一个问题,假如有一个句子 " the dog bark at the mailman". 假如用向量来表示每个单词,我们最先想到的是用 ...
- 零样本学习 - (Zero shot learning,ZSL)
https://zhuanlan.zhihu.com/p/41846072 https://zhuanlan.zhihu.com/p/38418698 https://zhuanlan.zhihu.c ...
- chrome 脚本学习
# 编写可复用的代码段(snippet)教程 https://jingyan.baidu.com/article/67508eb423d2929ccb1ce45b.html # chrome 脚本开发 ...
- jfinal的configPlugin基本配置代码
直接上代码: public void configPlugin(Plugins me) { // 这里是在数据库的配置文件中读取数据库的一些信息 DruidPlugin dbPlugin = new ...
- 在Visual Studio 2013顯示SCSS詳細錯誤訊息
在WebEssentials套件加持之下,Visual Studio 2013可以直接編修SCSS,每次存檔自動編譯出css.min.css及.map,非常方便.但初心者如我,寫錯語法在所難免,一旦造 ...
- HDU 5303 Delicious Apples(思维题)
Delicious Apples Time Limit: 5000/3000 MS (Java/Others) Memory Limit: 524288/524288 K (Java/Other ...
- 调试JDK1.8源码的方法
背景 在学习JDK源码的时候,免不了需要调试JDK的源码. 比如:想理解ConcurrentHashMap的put(K k, V v)方法,JDK自带的rt.jar文件是支持断点调试,但是却看不到变量 ...
- atitit.《金刚经》与it软件项目管理的启发 读后感attilax
atitit.<金刚经>与it软件项目管理的启发 读后感attilax 1.1. 经中宣称一切世间事物空幻不实,如梦幻泡如梦幻泡影,实相者则是非相.主 张 放弃对现实世间的执著或眷恋,以般 ...