利用.dSYM和.app文件准确定位Crash位置
2016-06-08 12:25
609 查看
http://blog.csdn.net/jinzhu117/article/details/20615991
利用.dSYM和.app文件准确定位Crash位置
分类: iPhone2014-03-0611:38 1505人阅读 评论(0) 收藏 举报
首先,确保在release(Ad Hoc或者App Store)一个版本时,保存了对应的xxx.app和xxx.dSYM文件。
其次,验证xxx.crash、xxx.app和xxx.dSYM三者的uuid是否一致。
验证方法:
1)查看xxx.app的uuid。
[plain] view
plaincopy
$ dwarfdump --uuid mobileguard.app/mobileguard
2)查看xxx.dSYM的uuid。
[plain] view
plaincopy
$ dwarfdump --uuid mobileguard.app.dSYM/Contents/Resources/DWARF/mobileguard
3)xxx.crash。
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命令。
Xcode6.1路径在:
Xcode6.0.app ▸ Contents ▸ SharedFrameworks ▸ DTDeviceKitBase.framework ▸ Versions ▸ A ▸ Resources
symbolicatecrash
[plain] view
plaincopy
$ 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。
[plain] view
plaincopy
export DEVELOPER_DIR="/Applications/Xcode.app/Contents/Developer"
然后执行命令:
[plain] view
plaincopy
symbolicatecrash m.crash mobileguard.app.dSYM > n.crash
接下来是最重要的环节:
[plain] view
plaincopy
$ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000
下面这个是我机器上看到的结果:
[plain] view
plaincopy
$ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000
-[MobileLocationViewCtrl viewDidLoad] (in mobileguard) (MobileLocationViewCtrl.m:56)
顶0
相关文章推荐
- 使用innodb_force_recovery解决MySQL崩溃无法重启问题
- 基于Android应用中如何反馈Crash报告的详解
- 查看iOS Crash logs的方法
- 解决QSqlTableModel::setData()崩溃的问题
- 使用 Crash 工具分析 Linux dump 文件
- linux kdump crash
- [Android]记录程序崩溃Log
- actor框架-Akka
- ios crash log的解析
- iOS 捕捉异常 写文件
- 最新CAX/EDA/CFD/GIS/光学/化工/液压软件资源网
- 6-24 CNN
- 如何从内核态重启系统
- 【转的】MUD驱动程序
- win8下metro风格应用程序的生命周期
- 关于MAP文件的使用----crash
- Qt程序只运行一个实例
- GetOpenFileName/GetSaveFileName之Crash和pdfshell.dll
- The model used to open the store is incompatible with the one used to create the store错误
- 闰秒(leap second)和linux/unix时间