iOS代码瘦身实践

原文
iOS代码瘦身实践

1 分析当前ipa的组成

一般一个ipa会包含:

1) 资源文件

  • 本地文件:数据、配置、数据库等等
  • 字体文件
  • 图片资源:1.删除不用的图片,2.检查重复的图片,3.压缩大图片
  1. 源代码

通过生成linkmap文件,分析源代码生成的编译文件的大小。在Build Settings中Write Link Map File设置为Yes (记住release时候不要设置为Yes)。

编译之后会在build目录中生成两个LinkMap文件: XXX-LinkMap-normal-i386和XXX-LinkMap-normal-x86_64,分别代表在模拟器中32位和64位指令集生成的LinkMap文件。关于LinkMap的文件详细结构解释可以参考:http://blog.cnbang.net/tech/2296/

LinkMap会包含每个可执行文件的偏移量及大小,所以可以很方便的知道每个可执行文件的大小。可以使用LinkMap分析工具:https://github.com/huanxsd/LinkMap

2 资源瘦身

无用的图片文件

查找无用的图片文件,使用LSUnusedResources(https://github.com/tinymind/LSUnusedResources

注意:如果是.bundle文件可以解压出来放到工程中,再用软件扫描
LSUnusedResourcesExample.gif

重复的图片文件

(同事在用,自己用了下没找到重复的文件,只找到相似的文件,所以不知道好不好,希望用过的同学说一下怎么样)

查找重复图像文件,使用Duplicate Photo Finder(App Store有免费下载)

无损压缩图片

使用ImageOptim(https://github.com/ImageOptim/ImageOptim)进行png文件的无损压缩

image

WebP图片压缩

WebP是Google提供的一种图片编码格式,通常情况下WebP格式的图片是原始JPG/PNG图片的1/3,所以对于重度依赖图片显示的应用,转换使用WebP可以节省大量的网络传输数据和时间。对于APP瘦身,使用WebP格式可能是一种方式,可以使用WebP格式的图片替代现有的图片资源,可以一定程度的节省空间。

使用WebP转换工具
https://developers.google.com/speed/webp/docs/precompiled)尝试转换了几张较大的图片,效果如下:

image

iOS原生并不支持WebP格式加载,需要引入SDWebImage/WebP,详细可以参考:http://blog.devzeng.com/blog/ios-webp-usage.html

NSString *path = [[NSBundle mainBundle] pathForResource:``@"logo"` `ofType:``@"webp"``];

NSData *data = [[NSData alloc] initWithContentsOfFile:path];

UIImage *img = [UIImage sd_imageWithWebPData:data];

self.imageView.image = img;

或者使用YYImage,加载WebP格式

CGFloat scale = [UIScreen mainScreen].scale;

NSData  *data = [[NSData alloc] initWithContentsOfFile:webPPath];

UIImage *img = [YYImage imageWithData:data scale:scale];
//UIImage *img = [YYImage imageNamed:webPPath];

使用WebP格式的图片,似乎就抛弃了iOS @2x @3x按照设备加载对应图片的机制,所以应该还可以删除所有@2x图片,不过加载速度比原生较慢。


2019.07.01补充

WebP转换软件:

XnConvert (Windows/Mac OS X/Linux) :AppsStore有下载
转的有问题,透明底色的图片出现白色底色

Webp 转换工具

线上工具:腾讯智图 、ppms-photo(http://ppms1.jd.com/photo)
本地工具:WebP Converter

WebP Converter 的安装请参见:https://developers.google.com/speed/webp/

mac 可用 homebrew 安装:

sudo brew install webp

使用以下指令转换 webp

cwebp -q 80 image.png -o image.webp

具体参见:https://developers.google.com/speed/webp/docs/cwebp

还有一个腾讯开发的iSparta,可以把图片转成WebP。

注释:

XnConvert 试了,转的有问题,透明底色的图片出现白色底色 :结果失败
WebP Converter试了,我安装失败了:结果失败
ppms-photo要翻墙,所以没试:结果没试
iSparta,后面才发现 :结果没试
最后我用都是腾讯智图 :结果成功



2019.07.01补充

网络加载

一些图片使用SDWebImage加载
例如:一些背景图

图片使用率提高

提高图片使用率
例如:一些UI背景图一样,只是文字不同,可以公用一张背景图,替换上面的内容

图片热更新

把图片,CSS样式等资源文件从项目中剥离出来,放到一个特定的目录里;然后,我们每次都这个特定地目录读取数据;最重要的是,我们可以动态更新这个目录,实现图片等资源文件的动态更新,即热更新.


3 代码瘦身

AppCode代码静态检查

AppCode提供了非常强大的代码静态检查工具,使用Inspect Code,可以找到很多代码优化的地方。可以参考这篇介绍:AppCode inspections for your code perfection

清除无用代码

AppCode搜索出来的无用的Class,会有误报需要仔细检查每一个报错的代码。

使用Fui(https://github.com/dblock/fui)查找发现下列无用文件,同样需要double check避免误删

清除无用的Import

Fui(https://github.com/dblock/fui)可以用于查找无用的import,同时也提供xcfui 可以和Xcode集成。

清除无用的Method

1. 基于AppCode的扫描定期做清理

你可以用 AppCode这个IDE。工具条Code-->Inspect Code...。是的,不要以为只有Xcode才能写OC, 这个工具可以把一些没有使用到了类、属性啥的都可以检测出来,还是那句话,不要一味地相信他人,要二次确认是否可删。

2. 这篇文章提供了一个很好的思路可以一键删除无用方法:http://www.jianshu.com/p/a53480ad0364

查找相似的代码

使用SameCodeFinder (https://github.com/startry/SameCodeFinder)可以查找到相似的代码,最后一位数字代表两个文件的海明距离,数字越小说明两个文件越类似。

清理其他无用的代码

1. 已经下线的陈旧代码,AB试验已经下线的代码

2. 通过转H5、Hybrid或者RN实现的Native功能,可以定期清理

3. 一些非核心Hybrid或者RN模块,可以考虑不要打包进入APP,通过动态下发的方式获取

4. 代码的重构,UI组件、业务逻辑的重用等等

4 一些参考文章

参考文章:
iOS代码瘦身实践
ipa文件“减肥”初探
iOS - ipa安装包大小优化
newiOS App优化1---减少包体积

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

推荐阅读更多精彩内容