Android DexHelper幫你解決65536問題

一. 前景

隨著Android平臺的持續(xù)成長谈秫,Android應用的大小也在增加。當應用及其引用的庫達到特定大小時卤妒,會遇到構(gòu)建錯誤息尺,指明你的應用已達到Android應用構(gòu)建架構(gòu)的極限。一般情況下贮竟,你會獲得類似的錯誤信息:

Dex: The number of method references in a .dex file cannot exceed 64K.
com.android.dex.DexIndexOverflowException: method ID not in [0, 0xffff]: 65536

二. MultiDex

2.1. 官方方案

Dex文件64K方法數(shù)的限制已經(jīng)被提及過很多次丽焊,Android官方也提供了MultiDex來解決這一問題。

2.2. 局限性

官方文檔中也指出了MultiDex的局限性:

  • 啟動期間在設備數(shù)據(jù)分區(qū)中安裝 DEX 文件的過程相當復雜咕别,如果輔助 DEX 文件較大技健,可能會導致應用無響應 (ANR) 錯誤。在此情況下惰拱,您應該通過 ProGuard 應用代碼壓縮以盡量減小 DEX 文件的大小雌贱,并移除未使用的那部分代碼啊送。
  • 使用 Dalvik 可執(zhí)行文件分包的應用可能無法在運行的平臺版本早于 Android 4.0(API 級別 14)的設備上啟動。
  • 使用 Dalvik 可執(zhí)行文件分包配置的應用發(fā)出非常龐大的內(nèi)存分配請求欣孤,則可能會在運行期間發(fā)生崩潰馋没。盡管 Android 4.0(API 級別 14)提高了分配限制,但在 Android 5.0(API 級別 21)之前的 Android 版本上降传,應用仍有可能遭遇這一限制篷朵。

在將應用配置為支持使用64K或更多方法引用之前,開發(fā)者應該采取措施減少應用代碼調(diào)用的引用總數(shù)婆排,包括由應用代碼或包含的庫定義的方法声旺。下列策略可幫助您避免達到 DEX 引用限制:

  • 檢查您的應用的直接和傳遞依賴項 - 確保您在應用中使用任何龐大依賴庫所帶來的好處大于為應用添加大量代碼所帶來的弊端。一種常見的反面模式是段只,僅僅為了使用幾個實用方法就在應用中加入非常龐大的庫腮猖。減少您的應用代碼依賴項往往能夠幫助您規(guī)避 dex 引用限制。
  • 通過 ProGuard 移除未使用的代碼 - 為您的版本構(gòu)建啟用代碼壓縮以運行 ProGuard赞枕。啟用壓縮可確保您交付的 APK 不含有未使用的代碼澈缺。

三. 工具

由于MultiDex存在的局限性,官方也給出了上述的兩個策略來輔助減少應用代碼調(diào)用的引用總數(shù)炕婶。

在實施這兩個策略之前姐赡,我們需要一個好用的工具來統(tǒng)計當前應用代碼的方法數(shù),在添加一個依賴庫之后古话,需要評估該依賴庫會引入多少方法雏吭,是否值得引用。

3.1. DexHelper

一款分析Dex文件的Gradle插件陪踩,在APK打包的同時杖们,輸出APK包中的dex文件相關信息: 引用方法數(shù)等。實現(xiàn)原理參考的官網(wǎng)Dex 格式肩狂,根據(jù)Dex文件格式摘完,解析APK包中的.dex二進制文件,獲取該dex文件中方法總數(shù)傻谁。

  1. 修改父項目build.gradle孝治,添加依賴com.ximsfei:dexhelper:version
buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.3.3'
        // 添加依賴
        classpath 'com.ximsfei:dexhelper:version'
    }
}

注: 最新version,以官方地址為準

  1. 修改子項目build.gradle审磁,應用插件com.ximsfei.dexhelper
apply plugin: 'com.android.application'
// 應用插件
apply plugin: 'com.ximsfei.dexhelper'
  1. 運行谈飒,通過assemble*命令打包apk,自動輸出結(jié)果
$ ./gradlew assemble -q
  DexHelper: apk file -> app-debug.apk
  DexHelper: dex file -> classes.dex
  DexHelper: method size -> 27022
  DexHelper: apk file -> app-release-unsigned.apk
  DexHelper: dex file -> classes.dex
  DexHelper: method size -> 27021

四. 總結(jié)

在選擇解決方案時态蒂,利用好的工具來評估實施方案的價值杭措,提高代碼運行效率,降低應用本身的體積钾恢,是每個開發(fā)者需要努力去做的手素。使用MultiDex來解決項目日益增長帶來的問題鸳址,不如在開發(fā)的過程中,將點滴細節(jié)做到極致泉懦。小工具大用途稿黍,DexHelper可以幫你將應用做到小而美。

項目地址: https://github.com/ximsfei/DexHelper

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末崩哩,一起剝皮案震驚了整個濱河市巡球,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌邓嘹,老刑警劉巖辕漂,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異吴超,居然都是意外死亡,警方通過查閱死者的電腦和手機鸯乃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進店門鲸阻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人缨睡,你說我怎么就攤上這事鸟悴。” “怎么了奖年?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵细诸,是天一觀的道長。 經(jīng)常有香客問我陋守,道長震贵,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任水评,我火速辦了婚禮猩系,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘中燥。我一直安慰自己寇甸,他們只是感情好,可當我...
    茶點故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布疗涉。 她就那樣靜靜地躺著拿霉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪咱扣。 梳的紋絲不亂的頭發(fā)上绽淘,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天,我揣著相機與錄音偏窝,去河邊找鬼收恢。 笑死武学,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的伦意。 我是一名探鬼主播火窒,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼驮肉!你這毒婦竟也來了熏矿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤离钝,失蹤者是張志新(化名)和其女友劉穎票编,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體卵渴,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡慧域,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了浪读。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片昔榴。...
    茶點故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖碘橘,靈堂內(nèi)的尸體忽然破棺而出互订,到底是詐尸還是另有隱情,我是刑警寧澤痘拆,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布仰禽,位于F島的核電站,受9級特大地震影響纺蛆,放射性物質(zhì)發(fā)生泄漏吐葵。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一犹撒、第九天 我趴在偏房一處隱蔽的房頂上張望折联。 院中可真熱鬧,春花似錦识颊、人聲如沸诚镰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽清笨。三九已至,卻和暖如春刃跛,著一層夾襖步出監(jiān)牢的瞬間抠艾,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工桨昙, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留检号,地道東北人腌歉。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像齐苛,于是被迫代替她去往敵國和親翘盖。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,486評論 2 348

推薦閱讀更多精彩內(nèi)容