这篇文章主要记录完成文哥的Android开发高手课Native层的崩溃异常捕获作业。
开发环境:window 10
开发软件:Android Studio 3.5.0 NDK-R16b Android 9.0(28)
NDK环境配置
先把sample导入到Android Studio,然后配置NDK环境
点击Show Package Details查看详细版本信息,如果CMake3.10.2的版本编译不过则降低到3.6.4版本
查找异常相关.dump文件
编译完成将app安装到模拟器上,进入/sdcard/ 下查看是否有.dump文件生成,结果发现只有crashDump文件夹并没有.dump文件
原因是NDK有GCC和Clang两套编译器,在Win10环境下只支持GCC编译。
使用NDK版本得选择r16b及以上版本。
- 笔者系统是win10 64,下载的是android-ndk-r16b-windows-x86_64.zip
- 然后修改AS中的NDK路径。File>Project Structure>SDK Location
然后分别在sample和breakpad-build的build.gradle中添加配置:
externalNativeBuild {
cmake {
cppFlags "-std=c++11"
arguments "-DANDROID_TOOLCHAIN=gcc"
}
}
重新编译打包,点击crash,则在/sdcard/crashDump/文件下看到xxx.dump文件
Crash日志转换分析
- 在sdk中的lldb中找到工具minidump_stackwalk.exe
- cmd命令窗执行命令,生成crash.txt文件
F:\AppData\Local\Android\sdk\lldb\3.1\bin>minidump_stackwalk.exe 7d178dfd-60a6-4bbc-f502b3be-f38a77c6.dmp >crash.txt
- 再使用NDK中addr2line来解析so得到具体发生crash的函数所在行。
F:\AppData\Local\Android\sdk\android-ndk-r16b\toolchains\x86_64-4.9\prebuilt\windows-x86_64\bin>x86_64-linux-android-addr2line.exe -f -C -e F:\Android_advance\Chapter01-master\sample\build\intermediates\transforms\mergeJniLibs\debug\0\lib\x86\libcrash-lib.so 0x515
到此分析结束,发现是crash.cpp在第10行发生crash,然后才回到代码修改bug。