iOS错误报告中关于崩溃地址的分析

http://blog.csdn.net/gaoyp/article/details/46912753

一、错误报告中的三种地址:
stack address
load address
symbol address


1)stack address
同意词:runtime address
从操作系统的堆栈0点算起,


2)load address
同意词或近意词:base address, slide address,start address
应用堆栈在操作系统堆栈中的起点。


3)symbol address
同意词:relative address
以load address为起点算起的偏移量。
注意:在崩溃报告中,此值为stack address - load address。
在dSYM文件中,一般设定load address为0x4000,这个值可用otool查。
所以在用symbol address在dSYM文件中查找对应的symbol时,需要 加 0x4000。


二、两种格式的崩溃报告:
1、
appname  0x97525 appname + 615717
2、
appname 0x97525   0x29000    + 615717


两种格式的对比:
app name  0x97525(stack address)                                           appname   + 615717 (symbol address)
appname   0x97525(stack address)  0x29000(load address)                      + 615717(symbol address)


一定注意计算时进制转换:symbol address是10进制,其它两个是16进制,以0x开头。


两种格式的区别就是第一种比第二种少了load address。


三、
三个地址间的运算关系:  
symbol_address  =  stack_address  -  load_address
由此可以推算出:
load_address =  stack_address - symbol_address


四、由地址得到symbol的命令:
命令行中的地址都必须转为16进制。
1、atos -o  appname.app.dSYM/Contents/Resources/DWARF/appname -arch armv7  symbol_address + 0x4000
3、atos -o MyApp.app/MyApp -arch armv7 -l stack_address load_address
2、dwarfdump -arch armv7 appname.app.dSYM --lookup  symbol_address + 0x4000

posted @ 2017-12-05 18:10  zzfx  阅读(438)  评论(0编辑  收藏  举报