Android 使用addr2line分析so异常

在 Android 开发中,addr2line 是一个用于将程序地址转换为源代码位置的工具。它通常用于分析崩溃日志或错误报告,以确定问题的源代码位置。
要在 Android 中使用 addr2line 工具进行问题分析,你需要获取崩溃堆栈信息,并识别其中的程序地址。然后,使用 addr2line 工具将程序地址转换为源代码位置。
下面是一个基本的使用示例:

  1. 先写一个异常

    extern "C"
    JNIEXPORT jstring JNICALL
    Java_com_test_jnitest_TestLib_stringFromJNI(JNIEnv *env, jobject thiz) {
        std::string hello = "Hello from C++";
        int* ptr;
        *ptr = 5; // 尝试对未初始化的指针赋值
        return env->NewStringUTF(hello.c_str());
    }
    
  2. 运行获取崩溃堆栈信息

     com.test.jnitest                     A  Fatal signal 11 (SIGSEGV), code 2 (SEGV_ACCERR), fault addr 0x722de89864 in tid 17168 (om.test.jnitest), pid 17168 (om.test.jnitest)
     crash_dump64                         A  pid: 17168, tid: 17168, name: om.test.jnitest  >>> com.test.jnitest <<<
     crash_dump64                         A        #00 pc 000000000002840c  /data/app/~~_dVrriJRajAtRrgPzNV3qQ==/com.test.jnitest-MEaj31G59slbtWaw_EWZxw==/base.apk!libjnitest.so (offset 0x476000) (Java_com_test_jnitest_TestLib_stringFromJNI+64) (BuildId: 546f68192868e6deb0630b50b9b0a275d4742350)
     crash_dump64                         A        #08 pc 00000000000009da  [anon:dalvik-classes4.dex extracted in memory from /data/app/~~_dVrriJRajAtRrgPzNV3qQ==/com.test.jnitest-MEaj31G59slbtWaw_EWZxw==/base.apk!classes4.dex] (com.test.jnitest.MainActivity.onCreate+98)
    
  3. 工具路径
    addr2line一般位于toolchains目录对应平台/CPU架构/位数32或64目录下
    如:ndk\21.4.7075529\toolchains\aarch64-linux-android-4.9\prebuilt\windows-x86_64\bin
    aarch64-linux-android-4.9:so库为arm架构 64位
    arm-linux-androideabi-4.9:so库为arm架构 32位

  4. 运行命令
    将so库复制到addr2line目录下,然后执行addr2line 工具将输出源代码位置,指示出问题发生的文件和行号:

     $ aarch64-linux-android-addr2line -C -f -e libjnitest.so 000000000002840c
     Java_com_test_jnitest_TestLib_stringFromJNI
     D:/workspace/JniTest/app/src/main/cpp/native-lib.cpp:5
    

你可能感兴趣的:(android,JNI,add2line)