Android之crash分析

前言

在Android日常开发中经常会遇到一些问题,需要我们通过分析log日子分析问题的原因,本文章记录一下在工作中遇到的一个crash问题分析.

抓log日子

首先第一步肯定是要从机器中拿到相关的log日子,如下图所示:

通过下面的log我们可以看到问题出在了com.airiche.sunchip.
log信息抓取

分析

pid: 1285, tid: 1295, name: HeapTaskDaemon >>> com.airiche.sunchip <<<
从这一行我们可以知道crash进程的pid和tid,知道进程号后我们可以往前翻翻log,看看该进程最后一次打印的log是什么,这样能缩小一点范围。

signal 6 (SIGABRT), code -6 (SI_TKILL), fault addr --------

再接下来的log打印出了cpu的所有寄存器的信息和堆栈的信息,这里面最重要的是从堆栈中得到的backtrace信息:

backtrace:
#00 pc 00042374 /system/lib/libc.so (tgkill+12)
#01 pc 0003ff81 /system/lib/libc.so (pthread_kill+32)
#02 pc 0001c73f /system/lib/libc.so (raise+10)
#03 pc 000198f1 /system/lib/libc.so (__libc_android_abort+34)
#04 pc 000174b0 /system/lib/libc.so (abort+4)
#05 pc 0031fe69 /system/lib/libart.so (_ZN3art7Runtime5AbortEv+212)
#06 pc 000f4239 /system/lib/libart.so (_ZN3art10LogMessageD2Ev+2092)
#07 pc 000f0a67 /system/lib/libart.so (_ZN3art7BarrierD2Ev+182)

然后通过命令去找到具体哪里报的错.

./prebuilts/gcc/linux-x86/arm/arm-eabi-4.8/bin/arm-eabi-objdump -S out/target/product/rk312x/obj/lib/ libc.so > libc.txt

在libc.so中找到42374如下:

42374: e1a0700c mov r7, ip
或者使用命令:
./prebuilts/gcc/linux-x86/arm/arm-eabi-4.8/bin/arm-eabi-addr2line -f -e out/target/product/rk312x/system/lib/libc.so 42374
直接显示哪一行的问题.

总结

暂时总结到这里,下次需要这个问题在进一步进行分析.

参考资料

https://blog.csdn.net/jack_chen_00/article/details/36190485
http://www.360doc.com/content/15/0813/11/8335678_491349700.shtml
https://blog.csdn.net/volcan1987/article/details/18604257
https://www.cnblogs.com/willhua/p/6718379.html

猜你喜欢

转载自blog.csdn.net/arunboy/article/details/100689907