在 Android 开发中,addr2line 是一个用于将程序地址转换为源代码位置的工具。它通常用于分析崩溃日志或错误报告,以确定问题的源代码位置。
要在 Android 中使用 addr2line 工具进行问题分析,你需要获取崩溃堆栈信息,并识别其中的程序地址。然后,使用 addr2line 工具将程序地址转换为源代码位置。
下面是一个基本的使用示例:
-
先写一个异常
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()); }
-
运行获取崩溃堆栈信息
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)
-
工具路径
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位 -
运行命令
将so库复制到addr2line目录下,然后执行addr2line 工具将输出源代码位置,指示出问题发生的文件和行号:$ aarch64-linux-android-addr2line -C -f -e libjnitest.so 000000000002840cJava_com_test_jnitest_TestLib_stringFromJNID:/workspace/JniTest/app/src/main/cpp/native-lib.cpp:5