iOS9 推出之后,大受欢迎。仅仅数周,已经有超过半数的 iOS 设备安装了这一新系统。这是 iOS 历代版本中采纳速度最快的—甚至打破了 2013 年 iOS7 创下的记录。
什么是应用瘦身?
“应用瘦身”(App thinning) 是美国苹果公司自iOS 9发布的新特性,它能对Apple Store和操作系统进行优化,它根据用户的具体设备型号,在保证应用特性完整的前提下,尽可能地压缩和减少应用程序安装包的体积,也就是尽可能减少应用程序对用户设备内存的占用,从而减小用户下载应用程序的负担。App thinning的实现主要有以下3种方法: Slicing、Bitcode和On-Demand Resources。以下将对这3种方法进行介绍。
《App Thinning》2015年9月24日,苹果在其开发者门户网站宣布,App Thinning 已被推迟,并没有包含在 iOS9(或9.0.1)的公开发布中:
然而,正如笔者在本文一开始提到过的,App Thinning 已经得到修复,所有运行 iOS 9.0.2 的设备都可以使用该功能。App thinning 是一种绝佳的工具,它将大大加快应用程序的下载速度!是一项可以改变整个下载进程的新技术。许多用户反应,流量费用过高、iOS 设备的存储空间有限,而下载速度却不断提升,为了适应这些问题,App Thinning 变得十分值得学习。此外,App Thinning 的发布已经推迟了,现在正是学习关于这一新技术的最好时机。
1. Slicing
在开发者将完整的应用安装包发布到Apple Store之后,Apple Store会根据下载用户的目标设备型号创建相应的应用变体(variants of the app bundle)。 这些变体只包含可执行的结构和资源等必要部分,而不需要让用户下载开发者提供的完整安装包。
下图展示了从开发者使用Xcode开发完整应用并发布到Apple Store后被用户下载到不同设备上的流程。
2.Bitcode
Bitcode使得开发者上传应用程序时不必非提交预编译的二进制文件,只需要上传“intermediate representation(直译为中间代表)”即可。而用户下载时,App Slicing可以根据用户需求,来判断你是需要32位还是64位。
也就是说,在用户下载应用之前,App Store在自动编译应用程序。这样,即使开发者没有给他们的代码添加标签,应用也能够执行App Slicing的部分功能,仅下载设备需要的32或64位代码。不过Bitcode也意味着如果苹果完善编译器提高代码效率,用户下载应用时苹果进行的完善会自动整合进去。
Bitcode 是 iOS 上较新的功能,对于新的项目需要手动开启。这可以通过选择Build Settings(编译设置)下的项目设置,将 bitcode 设为 YES 来完成。
虽然有评论表示,App Thinning这个新特性有时候也会带来不方便。比如用户坐十几个小时飞机,期间一直在玩游戏,持续过关斩将,但是因为没有下载所以不能继续玩下去,会感觉比较无奈。不过,对于大多数用户的应用场景来说,App Thinning将为iOS设备用户节省很多应用所需要的存储空间,对于16GB容量的iOS设备用户来说效果则更加明显。
iOS 9的更新包体积从原来的4.6GB降至现在的1.3GB,让不少8GB、16GB的iPhone和iPad老用户非常开心。而App Thinning方案进一步减小了系统在运行应用等多种实用情景时的存储资源占用,令人期待。
3.On-Demand Resources
ODR(on-demand resources 随需应变资源)是iOS减少应用资源消耗的另外一种方法。比如多级游戏,用户需要的通常都是他们当前的级数以及下一级。ODR意味着用户可以下载他们需要的几级游戏。随着你的级数不断增加,应用再下载其他级数,并将用户成功过关的级数删掉。
开启按需加载资源功能涉及改变 Xcode 中的设置(在编译设置(Build Settings)下),将「启用按需加载资源”选中为 是」
当用户点击应用内容的时候,就会动态从App Store上进行下载,也就是说用户只会在需要的时候占用存储空间。这项功能有趣之处还在于当将这些内容在后台进行下载之后,当存储空间紧张的时候会自动进行删除。
参考资料:
iOS APP安装包瘦身实践
漫谈iOS的应用瘦身
Working with App Thinning in iOS 9