Android调用堆栈跟踪实例分析

本文实例讲述了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开发的库。

希望本文所述对大家的Android程序设计有所帮助。

时间: 2024-10-27 07:03:48

Android调用堆栈跟踪实例分析的相关文章

Android调用堆栈跟踪实例分析_Android

本文实例讲述了Android调用堆栈跟踪的方法.分享给大家供大家参考.具体如下: Android开发中,我们也会经常遇到段错误,也就是SIGSEGV(11),这个时候libc的backtrace会打印出对应的堆栈信 息,而你看到的仅仅是一对数字,好像无从查起. 如下面这一从串断错误: ActivityManager( 1105): Displayed activity com.android.browser/.BrowserActivity: 2460 ms (total 2460 ms) I/

Android中ListView用法实例分析_Android

本文实例分析了Android中ListView用法.分享给大家供大家参考,具体如下: 通过在Layout中添加ListView Widget可以达到在页面布局具有列表效果的交互页面.在这里通过举例来说明怎样在Layout中添加ListView以及怎样应用. 配合设计了两个事件Listener:  OnItemSelectedListener事件为鼠标的滚轮转动时所选择的值:OnItemClickListener事件则为当鼠标单击时,所触发的事件.由此可以区别出list中的"选择"与&q

Android中AlertDialog用法实例分析_Android

本文实例分析了Android中AlertDialog用法,分享给大家供大家参考,具体如下: Android中AlertDialog为一些程序提供了对话框,有些功能能够进一步满足程序的需要.下面举例介绍. 程序如下: import android.app.Activity; import android.app.AlertDialog; import android.content.DialogInterface; import android.os.Bundle; import android.

Android中ImageView用法实例分析_Android

本文实例分析了Android中ImageView用法.分享给大家供大家参考,具体如下: 猜牌游戏大家可能以前都玩过,这里我们用这个小游戏来说明ImageView的用法. 首先,在res/drawable中引入三张牌:分别是梅花7,梅花8,梅花9 然后在res/layout/main.xml中配置一个TextView,三个ImageView以及一个Button <?xml version="1.0" encoding="utf-8"?> <Linea

Android中ListActivity用法实例分析_Android

本文实例分析了Android中ListActivity用法.分享给大家供大家参考,具体如下: 程序如下: import android.app.ListActivity; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.widget.ArrayAdapter; import android.widge

php调用mysql存储过程实例分析_php技巧

本文实例分析了php调用mysql存储过程的方法.分享给大家供大家参考.具体分析如下: Mysql存储过程创建语法,代码如下: CREATE PROCEDURE和CREATE FUNCTION : 复制代码 代码如下: CREATE PROCEDURE sp_name ([proc_parameter[,...]])       [characteristic ...] routine_body   CREATE FUNCTION sp_name ([func_parameter[,...]])

Android中AlertDialog用法实例分析

本文实例分析了Android中AlertDialog用法,分享给大家供大家参考,具体如下: Android中AlertDialog为一些程序提供了对话框,有些功能能够进一步满足程序的需要.下面举例介绍. 程序如下: import android.app.Activity; import android.app.AlertDialog; import android.content.DialogInterface; import android.os.Bundle; import android.

Android中ListActivity用法实例分析

本文实例分析了Android中ListActivity用法.分享给大家供大家参考,具体如下: 程序如下: import android.app.ListActivity; import android.os.Bundle; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.widget.ArrayAdapter; import android.widge

Android三种菜单实例分析

  本文实例讲述了Android的三种菜单.分享给大家供大家参考.具体分析如下: Android的菜单分为三种类型:选项菜单(Option Menu).上下文菜单(Context Menu).子菜单(Sub Menu) 一.选项菜单 当用户单击设备上的菜单按钮(Menu),触发事件弹出的菜单就是选项菜单.选项菜单最多只有六个,超过六个第六个就会自动显示 更多 选项来展示显示. 创建方法: 1.覆盖Activity的onCreateOptionsMenu(Menu menu)方法,当我们第一次打开