Android的native崩溃捕获与分析

1.集成BreakPad,产生一个native crash;输出到路径:

/data/data/fun.learnlife.breakpaddemo/files/crashDump

2.pull出来获取dmp文件。

3.使用minidump_stackwalk解析dmp文件,这里遇到一点麻烦,Windows平台很简单使用Android Studio\bin\lldb\bin下面的minidump_stackwalk即可。命令:D:\Program Files\Android\Android Studio\bin\lldb\bin>minidump_stackwalk.exe 1.dmp >crashLog.txt

Mac可能需要自己编译:

git clone https://github.com/google/breakpad

cd breakpad

./configure && make

输出在breakpad/src/processor/minidump_stackwalk

4.符号解析

Android的native崩溃捕获与分析

0x786为发生native crash的位置,然后用addr2line解析得到真正c++层报错的函数。这里可能会遇到问题,解析得到的是??:0这种结果,可能原因是你使用的so文件有问题,这里我遇到这个问题后直接选择abiFilters "armeabi-v7a",只生成armeabi-v7a平台的so。然后再用下面这个路径的so去解析。

命令:

/Users/lcy/Library/Android/sdk/ndk-bundle/toolchains/arm-linux-androideabi-4.9/prebuilt/darwin-x86_64/bin/arm-linux-androideabi-addr2line -f -C -e /Users/lcy/Desktop/WorkSpace/BreakPadDemo/app/build/intermediates/cmake/debug/obj/armeabi-v7a/libcrash-lib.so 0x786

执行结果:

Android的native崩溃捕获与分析

项目地址:https://github.com/Ulez/BreakPadDemo

提交写的集成步骤都很详细了,可以很简单的集成。