原文地址:https://www.jianshu.com/p/3caccc287346

如果大家是用真机在调试的过程中出现了Crash,那么请看iOS调试之 crash log分析

前言

导读:Understanding and Analyzing Application Crash Reports
众所周知,思维再缜密的人也会有百密一疏的时候,对于我们程序员来讲,更是会出现防不慎防的BUG。本文就来讲讲线上App崩溃Crash之后的找到奔溃原因的处理办法。

问题背景

最近频繁的在向Appstore提交新版本,在连续同样的问题被拒了多次了,运营那边也是苦恼,在测试的时候没有问题,但是一上传审核的时候就拒绝并且给出了crash文件。

拿到crash log之后我们激动的点开了,但是发现里面居然一脸懵逼,尤其是堆栈信息,如下:

Snip20170531_497.png

很是蛋疼,所以我们就开启了一段解析这些地址之旅。以下是一些概念和专业术语,希望大家好好了解下:

什么是dSYM文件

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

如果不用dSYM来符号化的话我们只能看到一堆的16进制地址,但是如果有这个dSYM文件我们就可以通过一些方法和手段将16进制的地址还原成函数或者方法名,供我们分析出现崩溃的原因。以下是符号化和未符号化或者半符号化的对比:
没有符号化:

Snip20170531_498.png

半符号化:

Snip20170531_499.png

全符号化:

Snip20170531_500.png

.dSYM文件准备

首先注意一点,dSYM文件是只有通过Xcode打包Archive出来的才有,所以必须经过正规打包,此处推荐大家看看iOS打包的两种方式,在推荐的此文中请大家参考打包方式一。以下是找到.dSYM文件的步骤:
第一步:Xcode中window-->Organizer

Snip20170601_504.png

Snip20170601_506.png

Snip20170601_508.png

第二步:选择对应的.xcarchive文件,右键显示包内容

Snip20170601_511.png

第三步:将第二步中截图的.dSYM文件拷贝到我们自定义的目录中,比如我们新建一个文件夹crash,那我们就把.dSYM文件拷贝到新建的crash目录中。(顺便把.app文件也拷贝到crash目录中)。(crash文件的路径:/Users/电脑名/Desktop/crash)

Snip20170601_512.png

PS: 如果是通过其他方式打包的,比如说通过iTunes打包的,那么是不会有这个.xcarchive文件的,也就不会有对应的.dSYM文件了,如果是这种情况的话,那现在你必须找到提交Appstore时候的版本(论版本控制的重要性),用同一台电脑(注意:一定是同一台电脑)然后用iOS打包的两种方式中的方式一再打一次包,使用Xcode重新上传到Appstore,如下图操作,再UpLoad to App Store。
1)修改一下配置:Build Settings-->搜dsym 选项改为DWARF with dSYM file

Snip20170601_515.png

2)再Archive一次,如果还没有,然后选择upload to App store,再选择的Download dSYMs:

Snip20170601_518.png

Symbolicatecrash工具

  • Symbolicatecrash是Xcode自带的一个分析工具,可以通过机器上的崩溃日志和应用的.dSYM文件定位发生崩溃的位置,把crash日志中的地址替换成代码相应位置。
  • Symbolicatecrash是Xcode上一个独立的工具,你打开终端是运行不了他的,因为环境变量没有配置,无法全局使用,所以现在只能先把这个工具在MAC上找到,然后拷贝出来,和.dSYM文件和Crash文件放在一起,然后再使用此工具。

Symbolicatecrash工具准备

1>路径:Symbolicatecrash工具的在xcode中的位置

  • Xcode4.3之前路径:
/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKit.framework/Versions/A/Resources/symbolicatecrash
  • Xcode4.3之后路径:
/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DTDeviceKit.framework/Versions/A/Resources/symbolicatecrash
  • Xcode6之后路径:
/Applications/Xcode.app/Contents/SharedFrameworks/DTDeviceKitBase.framework/Versions/A/Resources/symbolicatecrash
  • Xcode8之后路径:
/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash

PS: Xcode7和Xcode8 symbolicatecrash的路径

  • 如果大家发现这以上几种情况都找不到symbolicatecrash工具,那么不妨使用以下命令来找出symbolicatecrash工具的路径,在终端输入以下命令,稍等3分钟左右:
find /Applications/Xcode.app -name symbolicatecrash -type f

这三分钟主要是系统在搜寻symbolicatecrash工具的路径所耗费的时间,然后成功之后会显示以下截图:

Snip20170601_501.png

2>拷贝:将symbolicatecrash工具拷贝到上面创建的crash目录中

  • 进入到目录下找到symbolicatecrash直接拷贝,command+c:
Snip20170601_513.png

  • 或者是使用命令,将symbolicatecrash工具拷贝到相应路径:
cp /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/PrivateFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash /Users/电脑名/Desktop/crash

经过以上第一种直接拷贝或者命令拷贝的方式都能得到以下的结果:

Snip20170601_514.png

crash文件准备

把iTuenes Center的解决方案中心.crash文件下载下来,复制到crash文件夹中,或者如果是运营负责的话找运营要就好了。

Snip20170601_519.png

放好之后的结果:

Snip20170601_520.png

开始解析

  • 第一步:终端中进入到crash文件夹目录:/Users/电脑名/Desktop/crash
Snip20170601_523.png

  • 第二步:使用以下命令:
./symbolicatecrash ./*.crash ./*.dSYM > crash.log
Snip20170601_524.png

PS: 如果报以上错误,那么再输入如下命令:

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

然后再次输入命令./symbolicatecrash ./.crash ./.dSYM > crash.log
这个在解析的过程中需要一些时间的,稍等片刻,等到命令执行完成之后如下那么就可以看下crash.log文件了(当然你可以把crash.log改成你想要的任意后缀都行)

Snip20170601_525.png

  • 第三步:生成crash.log文件后,直接打开查看已经对自定的方法和类符号化了,但是对于系统的UIKit和Foundation并未符号话:
Snip20170601_526.png

PS:针对以上部分符号化的问题,请参见使用symbolicatecrash解析了一个crash log,其中提到了这个问题。

作者:KODIE
链接:https://www.jianshu.com/p/3caccc287346
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

iOS .Crash文件符号化相关推荐

  1. iOS Crash文件的解析(一)

    iOS Crash文件的解析(一) 2015-01-22 11:45 编辑: suiling 分类:iOS开发 来源:一片枫叶的博客 0 3913 iOS开发应用管理Crash文件进程调试 招聘信息: ...

  2. iOS: Crash文件解析

    原文出处: smileEvday   欢迎分享原创到伯乐头条 开发程序的过程中不管我们已经如何小心,总是会在不经意间遇到程序闪退.脑补一下当你在一群人面前自信的拿着你的App做功能预演的时候,流畅的操 ...

  3. 苹果审核返回崩溃日志 iOS .crash文件处理 symbolicatecrash

    AppStore审核被拒,返回crashLog.txt文件,可是打开后都是十六进制的地址,我们可以使用Xcode自带的symbolicatecrash解析得到我们需要的详细崩溃信息crashLogEn ...

  4. iOS--上线被拒如何从苹果返回的崩溃日志iOS.crash文件处理找崩点(看这篇就懂了)

    2017年底了,现在苹果上线的越来越严,导致被拒的次数也是越来越特多.我们从苹果给的提示可以看出我们大概崩溃的位置,但是作为程序员的我们,找到具体崩溃的点才能更好的修复. AppStore审核没有通过 ...

  5. iOS Crash日志分析必备:符号化系统库方法

    如果你有过分析iOS崩溃日志的经验,一定经常看到日志里出现很多<redacted>的字段.这篇文章就是帮助开发者将这些字段符号化为对应的系统库方法名. 如果你已经掌握了这方面的知识,就直接 ...

  6. 苹果官方 Crash文件分析方法 (iOS系统Crash文件分析方法)

    对于提交的苹果官方的app,在审核的时候会给我们一些crash文件,对于这些有用的文件,里面是关于我们的bug的一些信息,那么该如何去调试呢 第一步:在任意目录创建一个目录,用来调试crash,我这里 ...

  7. iOS奔溃分析技巧-crash日志符号化---symbolicatecrash

    iOS 使用symbolicatecrash分析crash文件 iOS 使用symbolicatecrash分析crash文件 首先,在桌面建一个文件夹crash,接着需要准备4个文件: 1.崩溃日志 ...

  8. iOS崩溃日志符号化及NLP聚类实现

    在解决iOS应用线上崩溃时,我们通常要分析崩溃日志来定位原因.线上崩溃日志一般是未符号或部分符号化的日志,是一堆十六进制的内存地址集合,可读性比较差,这对解决问题几乎没有帮助.所以,我们首先需要先对崩 ...

  9. 了解和分析iOS Crash

    作者:孟嵩,腾讯高级开发工程师  商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处. 原文链接:wetest.qq.com/lab/view/40- WeTest 导读 北京时间凌晨一点, ...

最新文章

  1. 【OpenCV 4开发详解】颜色模型与转换
  2. 探索JAVA并发 - 并发容器全家福!
  3. Java黑皮书课后题第10章:*10.5(显示素数因子)编写一个程序,提示用户输入一个正整数,然后以降序显示它的所有最小因子
  4. 我最喜欢的Java拼图2 + 1 = 4
  5. mysql 索引 内存_mysql索引【第三篇】
  6. Python之进程+线程+协程(异步、selectors模块、阻塞、非阻塞IO)
  7. 如何解决linux下编译出现的multiple definition of错误
  8. 阿里云安装宝塔打不开 已经开放安全组_centOS7 apache安装PHPMYADMIN
  9. windbg查询内存泄笔记
  10. 6 Linux之bash环境配置
  11. 依赖反转原则(DIP)
  12. 算法设计与分析——字符a~h出现的频率恰好是前8个斐波那契数——斐波那契数和霍夫曼编码的关系——数学证明
  13. 虚拟机如何与主机之间直接复制粘贴文件(使用VMware Tools)
  14. STM32F103 DMA方式GPIO输出
  15. 计算机网络中的猫,猫(调制解调器)和路由器有什么区别和功能?
  16. 神棍节献礼之——POJ1111 Image Perimeters(bfs)
  17. 【20考研】怎样迈出考研的第一步?
  18. Codingame平台“CHUCK NORRIS”的Python实现
  19. matlab rti dds,[译]*RTI_DDS测试
  20. 漫画:如何分别使用8种编程语言拯救公主

热门文章

  1. 新手小白 linux 常用命令笔记
  2. php怎样获取当前时间,php中获取当前时间的函数
  3. Leica 全站仪GSI数据格式(平面)
  4. C语言学习笔记06-占位符格式、C基本类型及逃逸字符一些细节(附介绍BCD码)
  5. DCN神州数码交换机端口安全配置命令(纯命令)
  6. 年薪20万招java讲师
  7. Nature Communications:人类丘脑的基因结构及其与十种常见大脑疾病的重叠
  8. 项目分包后出的测评报告能盖cnas/cma标识章吗
  9. (马蹄集)直线切平面 线段 圆切平面
  10. 轻松学习JavaScript十一:JavaScript基本类型(包含类型转换)和引用类型