版本記錄
版本號(hào) | 時(shí)間 |
---|---|
V1.0 | 2021.04.20 星期二 |
前言
隨著App的持續(xù)功能迭代和常年的運(yùn)營(yíng),最終包都會(huì)越來越大,包太大蘋果那邊會(huì)給限制,不利于用戶下載。所以App瘦身也是一項(xiàng)需要持續(xù)做的事。正好我這幾天就在做瘦身的事,這里記錄一下,大家一起學(xué)習(xí)和交流。
為什么要進(jìn)行包的瘦身?
隨著產(chǎn)品不停的進(jìn)行功能迭代,代碼以及圖片都越來越多,包的體積越來越大,但是包太大的話一個(gè)是用戶下載的流量消耗很大,二是蘋果也對(duì)用戶包大小下載有限制。所以,都是需要注意的,所以我們就要進(jìn)行包的瘦身。
測(cè)量方案
在瘦身之前你需要知道你的包現(xiàn)在有多大,同時(shí)也需要在某一個(gè)階段需要查看最終包的大小。
蘋果這邊體積計(jì)算方式有很多種:
- 1) 安裝體積(
App Store
看到的體積)。 - 2) 下載體積(實(shí)際下載占用的流量大小,用戶是無感知的,因?yàn)榭床坏剑?code>200M 限制下載看的是這個(gè)體積。
- 3) 自己的腳本計(jì)算體積,使用構(gòu)建后的
LinkMap
文件計(jì)算arm64
架構(gòu)下代碼段的體積 + 工程目錄下Pods
文件夾下出去代碼的資源文件得出。
因?yàn)榍皟煞N蘋果會(huì)根據(jù)系統(tǒng)和機(jī)型做不同處理,所以體積是不同的,也不具有衡量性。所以我們采用第三種方式作為我們的衡量指標(biāo),這種相對(duì)比較穩(wěn)定,也易于衡量。
1. LinkMap文件測(cè)量
我這邊使用LinkMap-master
對(duì)可執(zhí)行文件大小進(jìn)行計(jì)算,這里放的都是你的代碼等鏈接數(shù)據(jù),比如說你新增加了代碼,那么這個(gè)linkMap
就會(huì)變大。首先你需要獲取linkMap
文件,選中一個(gè)target
,在Xcode Build Setting
里Write Link Map File
設(shè)置為YES
,然后設(shè)置linkMap
文件的輸出路徑,在Path to Link Map File
里填寫你要輸出文件的路徑即可。
獲取到linkMap
文件以后,就使用一個(gè)常用的Mac
程序進(jìn)行解析了,還可以給出各個(gè)業(yè)務(wù)線不同的體積大小。這里由于敏感性我就不給出來我們項(xiàng)目的大小截圖了。
注意:這里一定不能用
debug
包的linkMap
,而是要用release
的,這兩個(gè)包因?yàn)閮?yōu)化的差異,親測(cè)大小要差不少。
2. 資源包測(cè)量
還有一個(gè)就是資源包大小的測(cè)量,這里我就是跑的腳本,直接計(jì)算項(xiàng)目里資源包有多大,最終會(huì)生成一個(gè)各個(gè)業(yè)務(wù)線的資源包體積大小,然后將這個(gè)結(jié)果和上面linkMap
測(cè)量結(jié)果加起來就是最終的包估計(jì)大小。腳本最終還生成了excel
文檔,給出了各個(gè)業(yè)務(wù)線不同的包的大小。
瘦身方案
包縮減的方案有很多,但是不管使用任何方法,歸根結(jié)底都是從兩個(gè)地方出發(fā):
- 減少包內(nèi)資源的體積,包括圖片等
- 減少代碼,即可執(zhí)行文件的體積
1. 減少資源包體積
這里可以從下面幾個(gè)方向入手:
- 減少不用的圖片,比如使用
LSUnusedResources
進(jìn)行掃描,里面還可以設(shè)置白名單,排除對(duì)某一個(gè)資源包的掃描。 - 壓縮現(xiàn)有的圖片資源,由于
png
是無損壓縮,所以你不用擔(dān)心壓縮導(dǎo)致失真的問題。壓縮工具比較多,比如熟知的tinyPng
網(wǎng)站就很不錯(cuò),簡(jiǎn)單好用,不用下載任何程序。
2. 減少代碼體積
- 刪除廢棄的代碼
- 有些三方模塊比較重的話可以廢棄或者用一些小的替換。
除了我上面提到的兩種我實(shí)踐過的方案外,還有另外幾個(gè)方向可以嘗試:
- 圖片格式的轉(zhuǎn)化,比如
png
可以轉(zhuǎn)化為webp
。- 蘋果提供的
ODR
的使用。
我們目前的包體積,還在可控范圍內(nèi),所以還沒有這兩張方式進(jìn)行縮減,同時(shí),業(yè)務(wù)線比較多,也需要和平臺(tái)各個(gè)業(yè)務(wù)線一起統(tǒng)籌做這個(gè)事。
參考文章
后記
本篇主要講述了
App
的包瘦身計(jì)算,感興趣的給個(gè)贊或者關(guān)注~~~