1 分析當前ipa的組成
一般一個ipa會包含:
1) 資源文件
- 本地文件:數據、配置、數據庫等等
- 字體文件
- 圖片資源
2) 源代碼
通過生成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)
無損壓縮圖片
使用ImageOptim(https://github.com/ImageOptim/ImageOptim)進行png文件的無損壓縮
WebP圖片壓縮
WebP是Google提供的一種圖片編碼格式,通常情況下WebP格式的圖片是原始JPG/PNG圖片的1/3,所以對於重度依賴圖片顯示的應用,轉換使用WebP可以節省大量的網絡傳輸數據和時間。對於APP瘦身,使用WebP格式可能是一種方式,可以使用WebP格式的圖片替代現有的圖片資源,可以一定程度的節省空間。
使用WebP轉換工具(https://developers.google.com/speed/webp/docs/precompiled)嘗試轉換了幾張較大的圖片,效果如下:
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;
使用WebP格式的圖片,似乎就拋棄了iOS @2x @3x按照設備加載對應圖片的機制,所以應該還可以刪除所有@2x圖片,不過加載速度比原生較慢。
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的掃描定期做清理
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可執行文件瘦身:http://blog.cnbang.net/tech/2544/
- iOS APP瘦身實踐:http://www.jianshu.com/p/c94dedef90b7,資源優化、編譯器配置優化、可執行文件優化
- 滴滴出行iOS端瘦身實踐: http://gmtc.geekbang.org/#schedule, 提供了查找無用圖片的工具、WebP圖片壓縮、基於clang plugin實現查找無用代碼(https://github.com/kangwang1988/XcodeZombieCode)、查找類似代碼(https://github.com/startry/SameCodeFinder)
- 基於clang插件的一種iOS包大小瘦身方案
- 減小ipa體積之刪除frameWork中無用mach-O文件