今天接受了一个改造旧项目的任务,据说项目唯独在iOS11上无法运行。这很容易就让我们想到与最近苹果iOS11放弃支持32位应用的事件有关。确实我在平时开发的项目中也没怎么涉及这个问题,这次在升级应用支持64位的过程中还是遇到了些问题,所以在这里总结一下,也许还会有同行的朋友遇到。
苹果于2013年9月推出了iPhone 5S新手机,采用的全新A7处理器其最大特色就是支持64位运算。64位A7处理器的使用意味着iPhone性能会大有提高,性能和速度更加出色;而要到达到这样的性能,开发者就要开发64位的应用了。因为即使64位的处理器再出色,如果还是安装32位的应用,那么64位处理的性能也不能发挥出来。
2018年1月1日开始,苹果在iOS 11系统上停止了32位应用程序的服务支持,使用iOS11系统的用户将无法再在Appstore中搜索到32位应用。同时32位的应用不顺应趋势也会停止继续开发,所以iPhone5s以下的机型也都面临着App停止更新的情况,因为从iPhone5s之后的iOS设备才是64位设备,而iPhone5以下都是32位设备,。
我们说到了32位和64位的处理器,它们本质的区别还是在于,64位多出2个寄存器,而这两个寄存器在运行32位应用的时候是关闭的,只有在运行64位应用的时候才会激活,才会用上。
这个区别对我们开发产生的影响在于,如果我们在项目中设置了支持不同的CPU架构,那么我们使用的静态库,动态库、以及打包的大小都会受到影响。关于在Xcode中设置不同CPU架构的支持可以参考下另一篇文章:(https://cloud.tencent.com/developer/article/1106932)
其实升级应用支持64位并不复杂,主要有以下两个步骤:
我们在Xcode中选择将要设置的target,然后打开build setting, 可以看到有关指令集设置的Architectures选项。
修改Vaild Architectures选项,增加arm64支持。
在经过上面的修改之后,我们的应用会编译失败。因为我们设置了项目需要支持arm64的架构,但是代码中使用的各个平台的SDK静态库还是只支持32位的。这就需要我们耐心的一个个更换了。这里有三个问题可能我们会遇到:
1.XIB报错:compiling IB documents for earlier than ios 7 is no longer supported
我们修改的这类项目通常也是比较旧的代码了,如果使用最新的Xcode打开我们可能会遇到上面的报错。我们可以进行如下的设置来修改这个错误。如果我们在Target->Deployment info ->Deployment Target 设置的是8.0的话,我们对于每个XIB文件也要做如下的修改: