android 之 Tombstone

Android 系统中的 Tombstone 是记录 Native 层崩溃信息的关键日志文件,当应用或系统服务因严重错误(如内存访问异常、空指针解引用等)崩溃时自动生成。以下是其核心机制与分析方法详解:

一、Tombstone 的生成机制

  1. 触发条件

    • 当 Native 代码(C/C++)发生致命错误时(如 SIGSEGV段错误、SIGABRT异常终止),Linux 内核会发送信号(Signal)给进程。
    • 系统注册的 debuggerd 守护进程捕获信号,收集崩溃现场信息并写入 /data/tombstones/ 目录,生成 tombstone_XX 文件。
  2. 文件存储

    • 路径:/data/tombstones/tombstone_00, tombstone_01 等(需 root 权限访问)。
    • 若无 root 权限,可通过 adb bugreport 导出完整报告后提取。

二、Tombstone 文件核心内容解析

文件包含以下关键信息(以典型字段为例):

plaintext 复制代码
Build fingerprint: 'Android/aosp_device_model'  # 设备固件标识
ABI: 'arm64'                                    # CPU架构
pid: 1234, tid: 5678, name: example_thread      # 进程/线程ID及名称
signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 0x0  # 崩溃信号类型和地址

backtrace:                                      # 崩溃堆栈
  #00 pc 00012345 /system/lib/libexample.so (functionA+0x10)
  #01 pc 00056789 /system/lib/libexample.so (functionB+0x20)

memory map:                                     # 内存映射
  00008000-00009000 r-xp 00000000 00:00 0 [heap]
  ffff0000-ffff1000 r-xp 00000000 00:00 0 [vectors]
关键字段说明
  • signalfault addr
    • SIGSEGV(信号11):通常由空指针或内存越界引发,fault addr 0x0 表示空指针解引用。
    • SIGABRT(信号6):断言失败或主动调用 abort()
  • backtrace
    堆栈调用链,pc 后为崩溃指令的相对地址(需结合符号表解析)。
  • memory map
    显示进程加载的模块地址范围,用于验证崩溃地址是否合法(如 0x0 属于非法地址)。

参考博客
android tombstone log分析
Android开发太难了,Native Crash的一切!

相关推荐
CYRUS_STUDIO3 小时前
FART 脱壳某大厂 App + CodeItem 修复 dex + 反编译还原源码
android·安全·逆向
Shujie_L5 小时前
【Android基础回顾】四:ServiceManager
android
Think Spatial 空间思维6 小时前
【实施指南】Android客户端HTTPS双向认证实施指南
android·网络协议·https·ssl
louisgeek6 小时前
Git 使用 SSH 连接
android
二流小码农6 小时前
鸿蒙开发:实现一个标题栏吸顶
android·ios·harmonyos
八月林城7 小时前
echarts在uniapp中使用安卓真机运行时无法显示的问题
android·uni-app·echarts
雨白8 小时前
搞懂 Fragment 的生命周期
android
casual_clover8 小时前
Android 之 kotlin语言学习笔记三(Kotlin-Java 互操作)
android·java·kotlin
梓仁沐白8 小时前
【Kotlin】数字&字符串&数组&集合
android·开发语言·kotlin
技术小甜甜8 小时前
【Godot】如何导出 Release 版本的安卓项目
android·游戏引擎·godot