Android开发高手课——模块一 01 native崩溃异常捕获

这篇文章主要记录完成文哥的Android开发高手课Native层的崩溃异常捕获作业。
开发环境:window 10
开发软件:Android Studio 3.5.0 NDK-R16b Android 9.0(28)

NDK环境配置

先把sample导入到Android Studio,然后配置NDK环境
Android开发高手课——模块一 01 native崩溃异常捕获_第1张图片
点击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
    Android开发高手课——模块一 01 native崩溃异常捕获_第2张图片
    然后分别在sample和breakpad-build的build.gradle中添加配置:
    Android开发高手课——模块一 01 native崩溃异常捕获_第3张图片
 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

Android开发高手课——模块一 01 native崩溃异常捕获_第4张图片

  • 再使用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。

你可能感兴趣的:(Android,Android性能优化)