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