浅谈 iOS 之 Crash log 符号化

码界捕手漫游
• 阅读 2324

其实,对于做移动 APP 开发的同学来说,质量和体验都是同等重要的。一个 APP 应用如果经常「闪退」,是产品质量很差的一个体现,那么用户体验就更不用再提了。

浅谈 iOS 之 Crash log 符号化


上面是笔者截取的国外一家公司对用户行为分析漫画的一个片段,从图中可以看到,有 80%的用户会因为网络错误和崩溃抛弃这个 APP,有 86% 的用户,如果体验太差,绝对不会第二次使用该 APP。所以开发一个优秀的 APP,性能即生死,一定尽量杜绝「闪退」。

诚然,iOS 上的 APP 闪退有各种各样的原因,像三方库不兼容、响应超时、内存不足都有可能造成 Crash。但更多情况下可能是 APP 程序自身的运行逻辑存在问题。比如调用用了 Objective-C 对象根本不支持的方法(发送消息),非法内存访问,数组越界,参数不符合要求等。

这些问题在调试阶段,我们很容易通过给 Xcode 打断点来进行调试, 但对于已发布的 APP,如果想重现并利用上述办法来解决,恐怕会比较费时费事。

最有帮助最直接的办法就是根据出现问题时的闪退日志,分析和判断 Crash 的原因,快速准确的定位和解决。

Crash log

在 iOS 上运行的 APP 出现 Crash 的时候,通常会生成一个 Crash log,记载问题发生时的具体状况。开发者可以在 iTunes Connect 中特定 APP下找到收集上来的 Crash log。也可以连接电脑,去本地目录找`
Mac :~/Library/Logs/CrashReporter/MobileDevice/<DEVICE_NAME>` 这个时候你会发现一大堆的.crash 文件和.ips 文件。
浅谈 iOS 之 Crash log 符号化

不过笔者还是推荐第三种,通过 Xcode 获取到崩溃日志,方法是 Xcode->Window->Devices,想必很多开发者和笔者一样,也都是用的是这个方法。

浅谈 iOS 之 Crash log 符号化

通过上面三种方法收集到了 Crash log,但用文本编辑器打开文件是一堆十六进制的内存地址,你会郁闷的发现压根看不懂。这又是另一个话题了。

Crash log 的分析

Crash log 里面包含了 Crash 发生的 APP、运行软硬件环境、发生时间、错误类型、方法调用异常栈、各线程状态、寄存器和内存信息。

而其中对我们开发人员来说意义最为重大的,可能就是异常线程的调用栈. 可惜有些时候,这关键的信息竟然全是 16 进制的数据,所以我们很难看懂。比如:

1CrashDebugInfoTest 0x1000c2b90 0x1000bc000 + 27536

那么要从十六进制的地址码,得到我们代码中对应的方法调用,就需要结合调试信息对 Crash log 进行符号化。笔者查看了很多文档,能符号化 Crash log 无非就 3 种方法:

1. 使用开发工具库中自带的 symbolicatecrash
2. 使用 atos
3. 使用 dwarfdump

前两种方法方法,都简单的试了一下,但并没有觉得有多好用,atos 要想把十六进制的地址翻译为符号,需要每次给 APP 打包时生成的 dSYM 文件,个人觉得很是麻烦。而 symbolicatecrash 也是如此,每次都需要在终端输入一些命令,也是劳心费神!

在这个当下这个这个注重效率的时代,笔者不认为手动的去做这些事情是好的。如果能借助一些工具去解决事情,那就再好不过了。仔细找了找,国内外还真有一些三方工具能解决这个问题。

国外的比如 New Relic,还有国内 OneAPM 的Mobile Insight

他们不仅解析了 Crash log,而且能将你所有的 Crash 进行分类,做成可视化的,不仅能直观的看到造成你 APP 崩溃的代码行,而且帮你统计出这个崩溃是在哪个iOS 系统和机型下发生的,这个崩溃影响了多少你的终端用户,堆栈信息也一目了然。

浅谈 iOS 之 Crash log 符号化

起初,笔者也不确定他是否能将所有崩溃类型都能抓到,于是在 Github 上下载了CrashProbe-master,一个崩溃类型相对比较全的开源 Demo 亲自测了一下,像常见的像无效内存地址,空指针未初始化指针,栈溢出造成的 SEGV:(Segmentation Violation)类型和线程异常造成的EXC_BAD_INSTRUCTION类型的崩溃等十几种崩溃都抓取到了
,感觉还是很惊讶。立马和身边一块做项目的安卓同事念叨了一下,他导入安卓的SDK 之后,简单的模拟了几个 Crash,神奇的是,竟然还有崩溃轨迹,就是在发生崩溃之前你都进行了什么操作,都可以看的到。当时,笔者心里就有点不平衡了,为啥 iOS 就没有,去问了他们的技术支持,说是下一期就能加上,很是期待啊!备注:本文已经得到原作者的同意,授权 OneAPM 技术博客进行转载

OneAPM Mobile Insight 以真实用户体验为度量标准进行 Crash 分析,监控网络请求及网络错误,提升用户留存。访问 OneAPM 官方网站感受更多应用性能优化体验,想阅读更多技术文章,请访问 OneAPM 官方技术博客

点赞
收藏
评论区
推荐文章
实例|APICloud AVM框架开发视频会议APP
APP开发采用的APICloud平台的AVM多端应用开发框架,使用avm.js一个技术栈可同时开发Android&iOS原生App、小程序和iOS轻App,且多端渲染效果统一;全新的App引擎3.0不依赖webView,提供百分百的原生渲染,保障App性能和体验与原生App一致;现有api直接映射兼容小程序接口,延续
Stella981 Stella981
3年前
Android 多渠道打包原理和使用
每次中午吃饭总会和技术同学聊天。当做iOS开发的做安卓开发的人员在一起的时候,他们中间又多了一个话题:iOS开发难还是安卓开发难。这个时候做安卓开发的同学最激动说安卓开发要自己画界面、机型复杂、操作系统多rom又被各家改的四不像....开发一个安卓APP的时间将近是开发iOS所需时间的2倍。iOS开发的同学可能就会反驳说
Stella981 Stella981
3年前
PhoneGap设置Icon
参考:http://cordova.apache.org/docs/en/latest/config\_ref/images.html通过config.xml中的<icon标签来设置Icon<iconsrc"res/ios/icon.png"platform"ios"width"57"height"57"densi
Stella981 Stella981
3年前
IOS之UIWebView的使用
刚接触IOS开发1年多,现在对于混合式移动端开发越来越流行,因为开发成本上、速度上都比传统的APP开发要好,混合式开发是传统模式与PC网页端相结合的模式。那么提到了APP的混合模式开发,在Android开发中有WebView作为混合模式开发的桥梁,当然在IOS中也同样有一个UIWebView组件来作为混合模式开发的桥梁,那么下面就对UIWebVi
Stella981 Stella981
3年前
OSChina 技术周刊第二十六期 —— 未来 Docker 的安全
每周技术抢先看,总有你想要的!移动开发1.【博客】JFinalJqueryMobile日志记录webapp效果图(http://my.oschina.net/realfighter/blog/387477)2.【博客】IOS开发—App在IOS8的simulator运行时,定位卡死
Stella981 Stella981
3年前
React Native与ExMobi技术路线探索
随着Facebook陆续开源ReactNative的iOS和Android版本,这种以JavaScript来开发原生APP的方式在移动应用开发圈里得到广泛关注,虽然ReactNative并不是第一个采用JavaScript编写原生APP的产品,但是其独特的设计思想和实现方式是非常值得借鉴的。而作为国内老字号的移动应用开发平台,同样支持开发原生APP
Stella981 Stella981
3年前
Android自动化页面测速在美团的实践
背景随着移动互联网的快速发展,移动应用越来越注重用户体验。美团技术团队在开发过程中也非常注重提升移动应用的整体质量,其中很重要的一项内容就是页面的加载速度。如果发生冷启动时间过长、页面渲染时间过长、网络请求过慢等现象,就会直接影响到用户的体验,所以,如何监控整个项目的加载速度就成为我们部门面临的重要挑战。对于测速这个问题,很多同学首先会想到在页面
Stella981 Stella981
3年前
IOS和android交互
第一次做和原生app的混合开发,其中有一些活动页面需要我这边用h5来做。那么必定涉及一个问题。就是和原生app做交互。分为ios和android。方法不同,逻辑思路都差不多。大体思路就是我和app端约定一个方法,类似于?接头暗号?比如说我们约定了一个方法:’蓝天白云‘,那么当我js调用这个方法的时候,app端通过'蓝天白云',认出了我,并作出
Wesley13 Wesley13
3年前
IOS上线过程详解
众所周知,苹果的APP都是人工审核的,只一点比安卓的好,安卓的一些软件上传到第三方之后估计压根就没人测试,下载了之后直接闪退或者美观性很差劲,更不要说用户体验了,那么,苹果的APP怎么一步步的上传到应用商店呢?下边我就我上一个项目的流程说一下首先你要有开发好APP,然后你需要花费99$去买一个账号,以前手机开发和mac开发分开的,现在可以通用了,然后
Stella981 Stella981
3年前
Android平台零代码快速集成AGC性能管理服务
  在使用手机应用的时候,经常会有应用打开慢、界面卡顿无反应、应用闪退、网络加载失败等问题,这些应用性能问题,都是影响用户体验的罪魁祸首。  随着手机应用性能的重要性逐步提升,越来越多监控应用性能的产品也应运而生。华为AppGalleryConnect(以下简称AGC)提供了应用开发,测试,发布以及分析的全流程的质量服务。1\.华为AGC性能管理
Stella981 Stella981
3年前
30天如何实现超级APP从0到1开发?京东mPaaS EMOP最佳示范来了
!(https://pic3.zhimg.com/80/v2af9f6637b50b09be60b00a42f3812d5e_1440w.jpg)当前,随着移动通信市场的成熟,企业提供服务的商业模式也随之改变,几乎每一个涉足移动互联网的企业都要拥有一款自己的APP。在此过程中,企业如何解决用户体验、质量把控、业务验证和研发速度等方面的挑战,对于快速