app上线后ios8系统踩过的坑

项目上线,app最低支持的系统版本是iOS8+,而我们公司的有一些用户还是使用ios8的系统一直没有升级,而我们公司没有iOS8的测试机(之前有最后都被升级了)。所以项目上线后用户反馈和Bugly统计了大量的crash日志信息。现在集中记录下有iOS8导致的crash,让后人以免踩坑。

ios8Crash总结

  1. 项目使用Carthage集成的第三方库YTKNetwork.framework在iOS8系统设备上启动就闪退,闪退信息如下:

    YTKNetwork的crash

    在GitHub的YTKNetwork下面的issues提问还是没能解决,讨论说是使用Carthage集成就是会存在这么个问题,最后只好将这个库里YTKNetworkAgent.m类中的源码相关requestPriority的部分注释掉才给解决的!
    解决方案

  2. iOS8系统使用的自提示Helvetica,iOS9系统中文系统字体变为了平方(PingFangSC)字体,导致在iOS设备上使用此方法时UIFont *font = [UIFont fontWithName:@"PingFangSC-Medium" size:17]font为空,进而导致使用这么使用时@{NSFontAttributeName: font}会crash,信息如下:

    font crash

    但是如果使用swift的写法就安全多了,我们可以知道let font = UIFont(name: "PingFangSC-Medium", size: 17)中的font这是个optional值可能为空,我可以给一个默认值。Objective-C解决crash的方案有两种:一是使用先判断是否为nil;二是使用[NSDictionary dictionaryWithObjectsAndKeys:font, NSFontAttributeName, nil];
    而且,iOS8系统字体间隙变大导致 UI 显示异常,平方字体比Helvetica字体有轻微的加粗效果,字体间距也变大了,,所以布局方面一些UILabel写死width的就会有问题,解决方案是计算label 的size并且向上取整ceilf(),

  3. iOS8中单例中的UIKit类中使用addTarget(_ target: Any?, action: Selector, for controlEvents: UIControlEvents)添加的action事件,并不会随着控制器而销毁,导致第二次并不会执行二是直接crash。GitHub demo地址,ios8模拟器运行效果如下,但是在iOS9+中运行是没有问题的,它对应action会执行两次。

    crash.gif

    这也从另一方面说明单例模式不能够滥用,因为他是常驻内存的,只有当app杀死的时候才能够被释放。我们app用户使用时crash就是因为我们代码写的很不严谨,本不需要使用单例模式却使用了单例模式!

  4. iOS8执行某一个动画时直接crash,并且crash信息如下:'-[CIContext initWithOptions:]: unrecognized selector sent to instance 0x18961850'
    搜索stackoverflow的解答找到原因是swift的let ciContext = CIContext(options: nil)的原因导致的,最后写了个OC的分类给解决了。另一个解决方案是针对iOS8的系统就不执行动画

  5. iOS8 UITableView crash的信息 Attempt to create two animations for cell,解决方案:stackoverflow的回答

以下是上传到AppStore所遇到的问题

  1. 使用Application Loader交付应用时,报如下错误。原因:打包build号没有修改,这个最好写个打包自动修改build号的脚本,人工打包很容易忘记修改build号,脚本自行网上搜索;
    F30AC746-D254-4419-9603-D2943D29C1A2.png

2.** 使用Application Loader交付应用时,报如下错误信息。原因:使用的一些第三方库如:MJRefresh.framework、SwiftyJSON.framework包含有不支持上线的 x86_64、i386架构;**

ERROR ITMS-90087: "Unsupported Architectures. The executable for leapParent.app/Frameworks/MJRefresh.framework contains unsupported architectures '[x86_64, i386]'."
ERROR ITMS-90087: "Unsupported Architectures. The executable for leapParent.app/Frameworks/Pulsator.framework contains unsupported architectures '[x86_64, i386]'."
ERROR ITMS-90087: "Unsupported Architectures. The executable for leapParent.app/Frameworks/SnapKit.framework contains unsupported architectures '[x86_64, i386]'."
ERROR ITMS-90087: "Unsupported Architectures. The executable for leapParent.app/Frameworks/SwiftyJSON.framework contains unsupported architectures '[x86_64, i386]’."

解决方案:添加去除x86_64、i386架构的脚本

推荐阅读更多精彩内容