现在的位置: 首页 > 综合 > 正文

如何查看没有symbol的崩溃日志

2013年09月14日 ⁄ 综合 ⁄ 共 751字 ⁄ 字号 评论关闭

smking:下面这种方式针对于这个设备本身就在咱们手中, 如果是在客户手中的话, 那么如何获取这个dsym文件倒是个问题。

所以下面这种方式的前提是基于设备在我们手中。

1,获取dSYMs文件中的image

其路径一般为:~/Library/Developer/Xcode/Archive/YYYY-MM-DD/AppName.xcarchive/dSYMs/AppName.app.dSYM/Contents/Resources/DWARF/AppName
2,计算崩溃日志中的实际运行地址
symbol address = slide + stack address - load address
其中:
1) slde就是LC_SEGMENT段中vmaddr的值,可以通过运行命令:
otool -arch ARCHITECTURE -l "APP_BUNDLE/APP_EXECUTABLE" | grep -B 3 -A 8 -m 2 "__TEXT"
ARCHITECTURE换乘崩溃是运行的架构,如armv7等。APP_EXECUTABLE换成第一步取得的image的路径/名称。
也可以使用
 atos -arch ARCHITECTURE -o APP_BUNDLE/APP_EXECUTABLE  -l 0x34000
。其中ARCHITECTURE和APP_BUNDLE/APP_EXECUTABLE的意思同上。0x34000即公式中的load address。该变量的取得见下文
2)stack address即log堆栈中的地址
3)load address即为日志中:
Binary Images:
   0x34000 -   0x50cfff +搜狗地图 armv7该行中的0x34000
3,进行查询
atos -arch armv7 -o AppName symbol address

抱歉!评论已关闭.