iOS crash分析定位

一、xcode源码安装

1.1源码以run的形式安装到手机并启动APP时(手机处于解锁状态);当crash时,会直接定位到源码某一行,这时候在手机上没有crash log

Note:在真机上运行时,需要signing,如图1. TARGETS下的General里有个Signing,这里需要Apple ID(测试时,可以用个人的账号,只是一般个人账号没有申请认证的情况下不能打包,只能源码安装到真机)

                           

1

 1.2源码以run形式(在Xcode 9以上build configurationrelease,一般情况下为debug)安装的,但是手动冷启动APP;当crash时,会在手机上生成一个crash log文件,通过Xcode打开这个log文件就能看到crash详细日志定位到某个方法或者某一行。

1.2.1build configuration配置:

如图2. Xcode中左上角,点击’project’名称,选择’Edit Scheme’

然后在图3. 中选择build configuration(以debug/release 方式编译运行)

 

2


1.2.2 查看手机上crash log 


4

如图4. 在连接手机情况下,从XcodeWindow中选择“Devices and Simulators”——>然后在界面中选择该手机的“View Device Log”——>log中选择要查看的 crash,如


5

5.  右边是具体的crash日志,找到 ‘Crashed ’标识 具体project的代码堆栈,就可以从中分析了。


二、.ipa包安装的

2. ipa包安装的crash日志是非源码,无法直接分析定位,必须符号化。

2.1 符号化需要相关文件和工具:

  1. .dSYM文件(crash那个ipa打包时产生的对应文件)
  2. .app文件(crash那个ipa打包时产生的对应文件;非必须,主要看采用什么工具,这里采用工具symbolicatecrash,可以不用)
  3. *.crash文件(获取日志途径同1.2.2
  4. 工具symbolicatecrashXcode自带的,在电脑的/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/路径下)

2.2 怎么符号化:

把上面2.1提到的相关文件放在同一个任意文件夹下,用命令工具进入该文件夹,执行命令./symbolicatecrash ./*.crash ./*.app.dSYM > symbol.crash(符号化后的文件,可以看到源码),如果执行命令时,提示相关找不到symbolicatecrash命令,需要配置环境变量/Applications/XCode.app/Contents/Developer

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jjhluxun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值