dsym定位crash

Archive 会把app 和dsym 打包在一起;

xcode —>organizer—>deviceLogs 可以自动翻译;

经典解释:
http://answerhuang.duapp.com/index.php/2014/07/06/dsym_tool/

https://github.com/answer-huang/dSYMTools

https://developer.apple.com/library/ios/technotes/tn2151/_index.html

首先,确保在release(Ad Hoc或者App Store)一个版本时,保存了对应的xxx.app和xxx.dSYM文件。
其次,验证xxx.crash、xxx.app和xxx.dSYM三者的uuid是否一致。

验证方法:

1)查看xxx.app的uuid。
$ dwarfdump --uuid mobileguard.app/mobileguard
2)查看xxx.dSYM的uuid。
$ dwarfdump --uuid mobileguard.app.dSYM/Contents/Resources/DWARF/mobileguard
3)xxx.crash。
.crash 文件内第一行 Incident Identifier 就是该 crash 文件的 UUID。

Note:

在这之前,需要找到对应的app和dSYM文件。这两个文件是在后缀为.archive的文件中,在我的机器(Mac OS 10.9.1,Xcode5.0.2)上,.archive文件在“/Users/mikelin/Library/Developer/Xcode/Archives/”文件夹下对应的日期文件夹中,也可以从Xcode > Organizer > Archive 下找到对应的Archive包。

确保三者uuid一致以后,用symbolicatecrash工具生成易读的日志信息。

先准备环境:

1)链接symbollicatecrash到/usr/bin/中,就可以直接使用sybollicatecrash命令。

$ ln  -s 
 /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKitBase.framework/Versions/A/Resources/symbolicatecrash /usr/bin/symbolicatecrash  ```
2)设置xcode DEVELOPER_DIR。
 ``` export DEVELOPER_DIR="/Applications/Xcode.app/Contents/Developer"   ```
然后执行命令:
 ```symbolicatecrash m.crash mobileguard.app.dSYM > n.crash   ```
接下来是最重要的环节:
 ```$ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000   ```
下面这个是我机器上看到的结果:
 ```$ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000  
-[MobileLocationViewCtrl viewDidLoad] (in mobileguard) (MobileLocationViewCtrl.m:56)   ```

参考:
http://blog.csdn.net/qq_26544491/article/details/54909043


你可能感兴趣的:(dsym定位crash)