Multidex Android DEX手動拆包

隨着業務規模發展到一定程度,不斷地加入新功能、添加新的類庫,代碼在急劇的膨脹,相應的apk包的大小也急劇增加, 那麼終有一天,你會不幸遇到這個錯誤:

Conversion to Dalvik format failed:Unable to execute dex: method ID not in [0, 0xffff]: 65536

具體原因如下:

http://tech.meituan.com/mt-android-auto-split-dex.html?hmsr=toutiao.io&utm_medium=toutiao.io&utm_source=toutiao.io

1.修改Gradle配置文件,啓用MultiDex幷包含MultiDex支持:

android {

defaultConfig {

        multiDexEnabled true

    }

}

dependencies {

        compile'com.android.support:multidex:1.0.1'

}

在AndroidManifest.xml的application中聲明android.support.MultiDex.MultiDexApplication;

如果你已經有自己的Application類,讓其繼承MultiDexApplication;

如果你的Application類已經繼承自其它類,你不想/能修改它,那麼可以重寫attachBaseContext()方法:

@Override

protected void attachBaseContext(Context base) {

    super.attachBaseContext(base);

    MultiDex.install(this);

}

MultiDex自動拆包帶來的問題:

1.在冷啓動時因爲需要安裝DEX文件,如果DEX文件過大時,處理時間過長,很容易引發ANR(Application Not Responding);

2.採用MultiDex方案的應用可能不能在低於Android 4.0 (API level 14) 機器上啓動,這個主要是因爲Dalvik linearAlloc的一個bug ;

3.採用MultiDex方案的應用因爲需要申請一個很大的內存,在運行時可能導致程序的崩潰,這個主要是因爲Dalvik linearAlloc 的一個限制,這個限制在 Android 4.0 (API level 14)已經增加了, 應用也有可能在低於 Android 5.0 (API level 21)版本的機器上觸發這個限制;

MultiDex手動拆包:

Android Studio 中提供了相應的手動拆包的方法:


1.multiDexKeepFile:手動加入要放到Main.dex中的類。

例:

android/support/multidex/MultiDex.class

2.multiDexKeepProguard:以Proguard的方式手動加入要放到Main.dex中的類。

例:

-keep class android.support.multidex.** {

    *;

}

build.gradle:

android {

    defaultConfig {

        multiDexEnabled true

        // 'multidex.pro'和build.gradle同一個目錄

        multiDexKeepProguard file('multidex.pro')

    }

}

dependencies {

    compile'com.android.support:multidex:1.0.1'

}

編譯時,相應的文件文件會加入到

build/intermediates/multi-dex/***/maindexlist.txt

build/intermediates/multi-dex/***/manifest_keep.txt

總結

上面是我在使用MultiDex過程中發現的DEX手動拆包的方案。由於時間倉促,項目要趕進度,所以直接貼代碼了,關於後續的MultiDex.install(this)異步加載方法和出現ClassNotFoundException的異常,以後再詳細的去寫吧。

發佈了36 篇原創文章 · 獲贊 7 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章