热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Android调用堆栈跟踪实例分析

这篇文章主要介绍了Android调用堆栈跟踪的方法,以实例形式较为详细的分析了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程序设计有所帮助。


推荐阅读
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文讲述了如何通过代码在Android中更改Recycler视图项的背景颜色。通过在onBindViewHolder方法中设置条件判断,可以实现根据条件改变背景颜色的效果。同时,还介绍了如何修改底部边框颜色以及提供了RecyclerView Fragment layout.xml和项目布局文件的示例代码。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • baresip android编译、运行教程1语音通话
    本文介绍了如何在安卓平台上编译和运行baresip android,包括下载相关的sdk和ndk,修改ndk路径和输出目录,以及创建一个c++的安卓工程并将目录考到cpp下。详细步骤可参考给出的链接和文档。 ... [详细]
  • 【Windows】实现微信双开或多开的方法及步骤详解
    本文介绍了在Windows系统下实现微信双开或多开的方法,通过安装微信电脑版、复制微信程序启动路径、修改文本文件为bat文件等步骤,实现同时登录两个或多个微信的效果。相比于使用虚拟机的方法,本方法更简单易行,适用于任何电脑,并且不会消耗过多系统资源。详细步骤和原理解释请参考本文内容。 ... [详细]
  • Android Studio Bumblebee | 2021.1.1(大黄蜂版本使用介绍)
    本文介绍了Android Studio Bumblebee | 2021.1.1(大黄蜂版本)的使用方法和相关知识,包括Gradle的介绍、设备管理器的配置、无线调试、新版本问题等内容。同时还提供了更新版本的下载地址和启动页面截图。 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文讲述了作者通过点火测试男友的性格和承受能力,以考验婚姻问题。作者故意不安慰男友并再次点火,观察他的反应。这个行为是善意的玩人,旨在了解男友的性格和避免婚姻问题。 ... [详细]
  • 安卓select模态框样式改变_微软Office风格的多端(Web、安卓、iOS)组件库——Fabric UI...
    介绍FabricUI是微软开源的一套Office风格的多端组件库,共有三套针对性的组件,分别适用于web、android以及iOS,Fab ... [详细]
author-avatar
外事一棵葱_712
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有