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

这篇文章主要记录完成文哥的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

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。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值