dSYM文件分析方法

在开发中很多项目使用了类似友盟统计的第三方统计工具,这样可以在友盟给出的错误信息统计中比较方便的找出客户端异常的信息,可是很多像数组越界却只给出了

1. *** -[__NSArrayM objectAtIndex:]: index 50 beyond bounds [0 .. 39]'

这类错误信息。遇到这种问题如果通过objectAtIndex去检索报错代码位置的话,那工作量巨大。

dSYM 文件

Xcode编译项目后,我们会看到一个同名的 dSYM 文件,dSYM 是保存 16 进制函数地址映射信息的中转文件,我们调试的 symbols 都会包含在这个文件中,并且每次编译项目的时候都会生成一个新的 dSYM 文件,位于/Users/<用户名>/Library/Developer/Xcode/Archives目录下,对于每一个发布版本我们都很有必要保存对应的 Archives 文件 (AUTOMATICALLY SAVE THE DSYM FILES)这篇文章介绍了通过脚本每次编译后都自动保存 dSYM 文件)。

当我们软件 release 模式打包或上线后,不会像我们在 Xcode 中那样直观的看到用崩溃的错误,这个时候我们就需要分析 crash report 文件了,iOS 设备中会有日志文件保存我们每个应用出错的函数内存地址,通过 Xcode 的 Organizer 可以将 iOS 设备中的 DeviceLog 导出成 crash 文件,这个时候我们就可以通过出错的函数地址去查询 dSYM 文件中程序对应的函数名和文件名。大前提是我们需要有软件版本对应的 dSYM 文件,这也是为什么我们很有必要保存每个发布版本的 Archives 文件了。

每一个 xx.app 和 xx.app.dSYM 文件都有对应的 UUID,crash 文件也有自己的 UUID,只要这三个文件的 UUID 一致,我们就可以通过他们解析出正确的错误函数信息了。

dSYM 工具

dSYMTools将这些命令封装到一个Mac OS版应用中,为以后查找定位bug提供了便利。

使用步骤:

选中任意一个版本的xcarchive文件,右边会列出该xcarchive文件支持的CPU类型,选中错误对应的CPU类型。

对比错误给出的UUID和统计工具中给出的UUID是否一致。

将错误地址以及 Slide Address 输入工具的文本框中,点击分析。

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在开发中很多项目使用了类似友盟统计的第三方统计工具,这样可以在友盟给出的错误信息统计中比较方便的找出客户端异常的信...
    Richard_Wei阅读 1,331评论 0 1
  • iOS-dsym分析crash日志我们在iOS开发中会碰到的很多crash问题,如果Debug调试模式的话,我们可...
    erbai阅读 2,515评论 0 1
  • 本文就捕获iOS Crash、Crash日志组成、Crash日志符号化、异常信息解读、常见的Crash五部分介绍。...
    xukuangbo_阅读 1,611评论 0 0
  • 来到新公司后,前段时间就一直在忙,前不久 项目 终于成功发布上线了,最近就在给项目做优化,并排除一些线上软件的 b...
    RobinYu阅读 784评论 1 2
  • 成言,这是干妈第一次给你写信。想发短信给你,祝你找到人生的第一份工作,却又觉得欲说不止。 毕业了,人生将开始新的征...
    乐土向欣阅读 287评论 0 0