平台介绍:Linux3.10.40 + Android4.4.2
事情的起因是压力测试过程中生成的tombstone日志异常,日志形式如下:
=======================================================================
*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
Build fingerprint: 'xxxx'
Revision: '0'
pid: 16471, tid: 16471, name: UNKNOWN >>> UNKNOWN <<<
signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 00000000
=======================================================================
第一个不正常的地方是"pid: 16471, tid: 16471, name: UNKNOWN >>> UNKNOWN <<<"中进程和线程id是有的,但是后边的进程名字和程序路径显示的都是"UNKNOWN"。第二个不正常的地方是调用栈信息无效。
在Adroid中,tombstone日志文件是由debuggerd进程生成,这部分日志保存在/data/tombstones目录中。logcat日志中还包含一些额外信息,形式如下:
=======================================================================
Fatal signal 11 (SIGSEGV) at 0x00000000 (code=1), thread 16471 (进程名)
*** *** *** *** *** *** *** *** *** *