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 客户端开发。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

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