随着不断迭代的APP,在产品需求以及功能模块的持续扩大下,缩减iOS安装包大小成为了很多中大型APP都要做的事,但具体如何实现呢?
其实应用包瘦身,无非就是从两个层面应对,一个是资源级别的优化,一个就是代码级别的优化。
一、资源瘦身
资源瘦身主要是去掉无用资源和压缩资源,资源包括图片、音视频文件、配置文件以及多语言wording。无用资源是指资源在工程文件里,但没有被代码引用。检查方法是,用资源关键字(通常是文件名,图片资源需要去掉@2x @3x),搜索代码,搜不到就是没有被引用。当然,有些资源在使用过程中是拼接而成的(如image_xxx.png),需要手工过滤。
下面介绍一个检查工程项目中无用图片资源的工具LSUnusedResources,搜索结果中的资源文件都为被引用但没有实际使用,但为确保安全无误,删除前还需要确保工程中没有使用。
资源压缩主要对png进行无损压缩,用的是ImageOptim工具。一般不建议对资源做有损压缩,有损压缩需要设计一个个检查,通常压缩后效果不尽人意。
二、代码瘦身
首先,使用LinkMap分析应用包中各个类以及第三方库在可执行文件里占用的大小,分析结束后就可以快速定位到需要进行优化的类或者静态库。当我们知道工程项目中的第三方库在可执行文件里占用空间大小时,就可以具体分析权衡是否有其他方案替代这些第三方库。
其次,删除无用代码。在项目里新建一个类,给它添加几个方法,但不要在任何地方import它,build完项目后观察LinkMap,你会发现这个类还是被编译进可执行文件了。
是因为object-c的动态特性,它可以通过类和方法名反射获得这个类和方法进行调用,所以就算在代码里某个类没被使用到,编译器也没法保证这个类不会在运行时通过反射去调用,所以只要是在项目里的文件,无论是否又被使用到都会被编译进可执行文件。
通过使用python脚本,遍历整个项目的文件,找出所有没有被引用的类文件和没有被调用的方法,在保证没有其他地方动态调用的情况下把它们去掉。下面就介绍几个优化的方法:
可能很多人对LinkMap文件不是很了解,《iOS调优 | 深入理解Link Map File》不懂得小伙伴可以看下这篇文件。
1.XCode开启编译选项Write Link Map File
XCode -> Project -> Build Settings -> 搜map -> 把Write Link Map File选项设为yes,并指定好linkMap的存储位置
2.编译后,到编译目录里找到该txt文件,文件名和路径就是上述的Path to Link Map File
文件位于~/Users/xxxxxxxxx/Library/Developer/Xcode/DerivedData/Jovi-dgmwdpjofxrufihidpjqqtomnphq/Build/Intermediates/Jovi.build/Debug-iphonesimulator/Jovi.build/Objects-normal/x86_64
接下来就是通过LinkMap工具来分析LinkMap文件了:
1、打开LinkMap.xcodeproj,并运行,就可以看到工具界面
2、点击“选择文件”按钮,选择LinkMap文件
3、点击“开始”按钮,就可以看到每个类/静态库所占用的空间大小
看完分析结果,可能很多人会以为,分析结果中包含的类及第三方库都是我们在项目真正使用到的,其实并不是,这是由于OC的动态性,它可以通过类和方法名反射获得这个类和方法进行调用,所以就算在代码里某个类没有被使用到,编译器也无法保证这个类不会再运行时通过反射去调用,因此只要是在项目中引用的文件,无论是否被使用到都会被编译进可执行文件中。那么如何找出来隐藏在其中的废弃代码,看起来是很困难的事情。
下面就为大家介绍几种瘦身工具:
1.python脚本,可以快速的找到项目中的无用方法。
执行:python selectorsunref.py 根据提示逐步输入,得到检索结果。
2.fui命令行,找出项目中废弃的文件
安装:gem install fui
检索:cd到项目目录下,执行fui find(此过程可能需要几分钟,请耐心等待)
搜索结果为项目中未使用的文件,但为确保安全无误,删除前还需要确保工程没有使用,避免误删。
作者简介
就职于甜橙金融(翼支付)信息技术部,负责 iOS 客户端开发。