APP包瘦身之路

随着不断迭代的APP,在产品需求以及功能模块的持续扩大下,缩减iOS安装包大小成为了很多中大型APP都要做的事,但具体如何实现呢?

其实应用包瘦身,无非就是从两个层面应对,一个是资源级别的优化,一个就是代码级别的优化。

一、资源瘦身

资源瘦身主要是去掉无用资源和压缩资源,资源包括图片、音视频文件、配置文件以及多语言wording。无用资源是指资源在工程文件里,但没有被代码引用。检查方法是,用资源关键字(通常是文件名,图片资源需要去掉@2x @3x),搜索代码,搜不到就是没有被引用。当然,有些资源在使用过程中是拼接而成的(如image_xxx.png),需要手工过滤。

下面介绍一个检查工程项目中无用图片资源的工具LSUnusedResources,搜索结果中的资源文件都为被引用但没有实际使用,但为确保安全无误,删除前还需要确保工程中没有使用。

LSUnusedResources

资源压缩主要对png进行无损压缩,用的是ImageOptim工具。一般不建议对资源做有损压缩,有损压缩需要设计一个个检查,通常压缩后效果不尽人意。


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,并运行,就可以看到工具界面

LinkMap

2、点击“选择文件”按钮,选择LinkMap文件

3、点击“开始”按钮,就可以看到每个类/静态库所占用的空间大小

分析结果

看完分析结果,可能很多人会以为,分析结果中包含的类及第三方库都是我们在项目真正使用到的,其实并不是,这是由于OC的动态性,它可以通过类和方法名反射获得这个类和方法进行调用,所以就算在代码里某个类没有被使用到,编译器也无法保证这个类不会再运行时通过反射去调用,因此只要是在项目中引用的文件,无论是否被使用到都会被编译进可执行文件中。那么如何找出来隐藏在其中的废弃代码,看起来是很困难的事情。

下面就为大家介绍几种瘦身工具:

1.python脚本,可以快速的找到项目中的无用方法。

执行:python selectorsunref.py 根据提示逐步输入,得到检索结果。

2.fui命令行,找出项目中废弃的文件

安装:gem install fui

安装

检索:cd到项目目录下,执行fui find(此过程可能需要几分钟,请耐心等待)


检索结果

搜索结果为项目中未使用的文件,但为确保安全无误,删除前还需要确保工程没有使用,避免误删。


作者简介

就职于甜橙金融(翼支付)信息技术部,负责 iOS 客户端开发。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文主要介绍了App包瘦身的优化步骤,资源部分处理的较多,但像三方库、可执行文件瘦身,涉及较少。 一、成果(ipa...
    小飞鱼_love阅读 457评论 0 0
  • 目录:000 - 苹果提供的 App Thinning (了解)001 - 项目结构介绍002 - 变更图片文件的...
    麦穗0615阅读 1,219评论 0 1
  • 参考公众号:WeMobileDev APP开发中,总会想要去尽可能的优化项目,这是我们作为程序员最基本的追求之一。...
    senpaiLi阅读 1,713评论 0 3
  • 缩减iOS安装包大小是很多中大型APP都要做的事,一般首先会对资源文件下手,压缩图片/音频,去除不必要的资源。这些...
    buptwsg阅读 1,993评论 0 8
  • 分析当前ipa的组成 源代码 通过生成linkmap文件,分析源代码生成的编译文件的大小。在Build Setti...
    斑驳的流年无法释怀阅读 5,666评论 0 14