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

转载 2016年06月01日 15:35:28
首先,确保在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开发有兴趣的朋友有所帮助。


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

利用.dSYM和.app文件准确定位Crash位置
  • jinzhu117
  • jinzhu117
  • 2014年03月06日 11:38
  • 15135

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

利用.dSYM和.app文件准确定位Crash位置 首先,确保在release(Ad Hoc或者App Store)一个版本时,保存了对应的xxx.app和xxx.dSYM文件。 其次...
  • LVXIANGAN
  • LVXIANGAN
  • 2014年06月02日 13:31
  • 3524

利用.dSYM跟.app文件准确定位Crash位置(详细)

看了其它的人博客,也写得很到位,但就是不够详细,好比,一些命令在哪些路径下面同有指出来,后来一个一个的试才出来。 首先利用.dSYM和.app文件准确定位Crash位置  首先,确保在releas...
  • dfasfds456123
  • dfasfds456123
  • 2016年07月19日 17:43
  • 180

apple appstore上线过程中 app crash的分析方法

apple appstore上线过程中 app crash的分析方法
  • jackyvan
  • jackyvan
  • 2016年03月12日 14:09
  • 867

dSYM,app,crash 文件 UUID 匹配

什么是 dSYM 文件Xcode编译项目后,我们会看到一个同名的 dSYM 文件,dSYM 是保存 16 进制函数地址映射信息的中转文件,我们调试的 symbols 都会包含在这个文件中,并且每次编译...
  • mtc1256
  • mtc1256
  • 2016年09月20日 15:59
  • 1276

通过dSYM和app文件分析Crash

一. 验证xxx.crash、xxx.app和xxx.dSYM的uuid是否一致 验证方法: 1)查看xxx.app的uuid       dwarfdump --uuid xxx.app/xxx...
  • sharpyl
  • sharpyl
  • 2015年12月04日 17:17
  • 1390

如何校验.ipa包、.dSYM、.crash文件的一致性

前言 https://developer.apple.com/library/ios/qa/qa1765/_index.html
  • andanlan
  • andanlan
  • 2016年05月08日 18:01
  • 3571

iOS通过dSYM文件分析crash

http://blog.csdn.net/hjy_x/article/details/20929095 我们在ios开发中会碰到的很多crash问题,如果Debug调试模式的话,我们...
  • openglnewbee
  • openglnewbee
  • 2014年08月25日 18:07
  • 24145

iOS - 命令行工具解析Crash文件,dSYM文件进行符号化

序 在日常开发中,app难免会发生崩溃。简单的崩溃还好说,复杂的崩溃就需要我们通过解析Crash文件来分析了,解析Crash文件在iOS开发中是...
  • yuqingzhude
  • yuqingzhude
  • 2017年01月10日 16:17
  • 971

友盟统计平台crash信息UUID与打包时生成.dSYM的UUID不一致

前言 在iOS应用的开发工作中,我们经常会用到一些开源的三方库或者一些三方服务,为了保证项目的稳定性,我们通常不会频繁的对项目中一些三方引用进行更新。一般情况下,只有在我们的项目中遇到一些由于三方依...
  • andanlan
  • andanlan
  • 2016年05月22日 17:48
  • 2132
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:利用.dSYM和.app文件准确定位Crash位置
举报原因:
原因补充:

(最多只允许输入30个字)