• 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());
      }
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
    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)
      
      • 1
      • 2
      • 3
      • 4
    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
      
      • 1
      • 2
      • 3
  • 相关阅读:
    【ConcurrentHashMap】JDK1.7版本源码解读与分析
    【云原生之K8s】 Kubernetes核心组件
    Terraform Chef Puppet
    (标签-微信小程序)
    在QML委托代理机制中使用C++数据模型
    中秋邀请共赏图数据库-蚂蚁集团图数据TuGraph 正式开源
    继(VScode上传到git仓库详细教程)后,创建新仓库以及上传新代码到git仓库教程
    【JavaScript—数据类型】
    MobaXterm的下载及简单使用(建立 SSH 连接到 Linux 服务器)
    服装界BOM的管理方式
  • 原文地址:https://blog.csdn.net/wolf0706/article/details/132696327