关闭

利用.dSYM和.app文件准确定位Crash位置

87人阅读 评论(0) 收藏 举报
分类:
首先,确保在release(Ad Hoc或者App Store)一个版本时,保存了对应的xxx.app和xxx.dSYM文件。

其次,验证xxx.crash、xxx.app和xxx.dSYM三者的uuid是否一致。

验证方法:

1)查看xxx.app的uuid。

  1. $ dwarfdump --uuid mobileguard.app/mobileguard  

2)查看xxx.dSYM的uuid。

  1. $ 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命令。

  1. $ 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。

  1. export DEVELOPER_DIR="/Applications/Xcode.app/Contents/Developer"  

然后执行命令:

  1. symbolicatecrash m.crash mobileguard.app.dSYM > n.crash  

接下来是最重要的环节:


  1. $ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000  

下面这个是我机器上看到的结果:

  1. $ xcrun atos -arch armv7 -o mobileguard.app/mobileguard 0x00037000  
  2. -[MobileLocationViewCtrl viewDidLoad] (in mobileguard) (MobileLocationViewCtrl.m:56)  

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

使用命令行工具atos 定位crash位置

1.从 appName.xcarchive 里提出 appName.dSYM 和 appName文件。放到一个目录下

2.使用终端进入这个目录,使用 xcrun atos arm64 -o appName 0x0000000100098000  

arm64是架构 ,appName是app文件,0x0000000100098000是基地址

以上就介绍了使用命令行工具atos 定位crash位置,包括了方面的内容,希望对IOS开发有兴趣的朋友有所帮助。


0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:101725次
    • 积分:2442
    • 等级:
    • 排名:第15174名
    • 原创:110篇
    • 转载:249篇
    • 译文:0篇
    • 评论:1条
    最新评论