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

你可能感兴趣的:(dSYM文件分析方法)