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.符号解析
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
执行结果:
项目地址:https://github.com/Ulez/BreakPadDemo
提交写的集成步骤都很详细了,可以很简单的集成。