Android NDK崩溃解决办法

崩溃信息signal 11 (SIGSEGV), code 1 (SEGV_MAPERR) 定位问题

在NDK开发的过程中,如果遇到应用Crash,JNI层的报错信息并不像java层那样可以看到详细的错误信息和错误位置,如果要想定位到错误位置,需要借助NDK的一些工具进行地址转换,本文中用addr2line(NDK的工具)来捕捉错误信息

以下是我的报错信息

image-20220526111816991

1.错误代号:signal 11 (SIGSEGV), code 1 (SEGV_MAPERR),一般都是空指针错误

2.错误发生所在的so文件:libalvr_client.so

3.错误发生的内存地址:000000000020a950,不能直接看到源代码发生错误的位置,所以需要用addr2line工具来定位

备注:记得一定要将logcat选择为No Filter才能看上全部错误信息,否则只看到signal 11 (SIGSEGV), code 1 (SEGV_MAPERR)这个信息,会让你怀疑人生

利用addr2line定位错误

  1. 首先找到addr2line的位置,我的addr2line位置为 /Users/Chendy/Library/Android/sdk/ndk-bundle/toolchains/aarch64-linux-android-4.9/prebuilt/darwin-x86_64/bin/aarch64-linux-android-addr2line,然后在Android studio的Terminal中定位到这个位置。

  2. 找到出错so文件的位置,在我的电脑中,发生错误的so文件是libvrapi.so,它的位置是 /Users/Chendy/Public/Rust/ALVR/alvr/client/android/app/src/main/jniLibs/arm64-v8a/libvrapi.so

  3. 然后在Terminal中

    1
    /Users/Chendy/Library/Android/sdk/ndk-bundle/toolchains/aarch64-linux-android-4.9/prebuilt/darwin-x86_64/bin/./aarch64-linux-android-addr2line -C -f -e /Users/Chendy/Public/Rust/ALVR/alvr/client/android/app/build/rustJniLibs/android/arm64-v8a/libalvr_client.so 000000000020a950

    image-20220526112440366

  4. 其中-C -f :表示打印错误行数所在的函数名称,-e:表示打印错误地址的对应路径及行数

windows参考这里