使用multidex解决64K方法引用的限制
1.什么是64K方法引用的限制
65536(64K)是單個dex(Dalvik Executable)字節碼文件的可引用的方法數的最大數,包括Android framework、應用的library和自己的方法。解決這個限制的方法就是使Apk編譯創建和使用多個dex字節碼文件在一個Apk文件中。
2.配置工程可以multidex
Android5.0之前的multidex設置
Android5.0(API 21)之前的版本使用Dalvik runtime虛擬機執行App代碼,默認情況下,Dalvik限制每個Apk文件只有一個dex字節碼文件。通過以下配置可以達到multidex的目的:
1.添加以下依賴,該依賴的library會包含在primary dex 文件中,且管理對其他dex文件及其代碼
dependencies {
compile 'com.android.support:multidex:1.0.1'
}
2.設置multiDexEnabled為true
defaultConfig {
...
minSdkVersion 21
targetSdkVersion 26
multiDexEnabled true
}
3.配置Applicaiton,視情況選擇以下三種之一
如果你沒有重載Application,在AndroidManifest.xml中配置如
<application
android:name="android.support.multidex.MultiDexApplication" >
...
</application>
下如果你重載了Applicaiton,選擇繼承如下類下
public class MyApplication extends MultiDexApplication{}
如果你重載了Application,并且無法繼承MultiDexApplicationAndroid5.0及更改版本的multidex配置
public class MyApplication extends SomeOtherApplication {
@Override
protected void attachBaseContext(Context base) {
super.attachBaseContext(base);
MultiDex.install(this);
}
}
Android5.0(api21)及之后的版本使用ART虛擬機,ART本身支持從Apk文件中加載多個dex文件。在App安裝時,ART會執行預編譯,掃描classN.dex并把它們編譯成一個系統可執行的.oat文件。因此,minSdkVersion為21及以上版本的,不需要配置multidex support library。只需要如下設置
defaultConfig {
...
minSdkVersion 21
targetSdkVersion 26
multiDexEnabled true
}
這樣配置后,Android構建工具會生成一個主dex文件,和classes2.dex、classes3.dex等等文件,在一個Apk文件中。在運行時,multidex APIs使用一個特別的類加載器搜索所有可用的dex文件
3.multidex support library的局限
multidex support library有以下已知和需要測試的局限
1.當App在設備數據區啟動時,dex文件的安裝是很復雜的,如果第二個dex文件很大,可能會可能會導致ANR。你可以使用混淆來減小dex文件的大小和移除無用的代碼
2.當運行在Android5.0之前的版本時,multidex并不能很好的解決linearalloc limit這個問題,該問題在4.0(api14)中引入,但并沒有完全解決。如果你想運行在Android4.0之前的版本上,最好多測試。使用混淆會減少甚至解決這個問題。
4.聲明需要在primary dex文件中的類
當構建multidex App的每個dex文件時,構建工具會執行復雜的決策來決定哪些類需要在primary dex文件中App才能正常啟動。如果有些類在啟動時需要,但沒有在primary dex文件中,會有java.lang.NoClassDefFoundError異常
你可以手動的指定一些類編譯在primary dex文件中,通過聲明multiDexKeepFile或multiDexKeepProguard屬性在build.gradle的buildTypes中
multiDexKeepFile的使用如下
1.首先創建文件,比如命名為multidex-config.txt,在該文件中指定包含在primary dex的類,格式為一行一個類,例如:
com/example/MyClass.class com/example/MyOtherClass.class
2.在build.gradle中配置該文件
android {
buildTypes {
release {
multiDexKeepFile file('multidex-config.txt')
...
}
}
}
multiDexKeepProguard參數同樣對應一個文件,該文件使用和Proguard一樣的格式且支持Proguard所有的語法。需要使用-keep來指定需要的類,如下:
-keep class com.example.MyClass -keep class com.example.MyClassToo
指定某個包下的類:
-keep class com.example.** { *; }
在build.gradle中配置
android {
buildTypes {
release {
multiDexKeepProguard file('multidex-config.pro')
...
}
}
}
5.優化開發構建中的multidex
使用multidex的配置需要顯著增加編譯時間,為了減少在開發中編譯時間,Android Studio做出了一些優化,在構建總用pre-dexing來復用multidex輸出,pre-dexing依賴于ART,只能在Android5.0及以上使用,Gradle3.0插件更有pre-class dexing等優化,建議升級Android Studio到最新版本并用5.0以上的設備測試
總結
以上是生活随笔為你收集整理的使用multidex解决64K方法引用的限制的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据结构(单链表的相关操作)
- 下一篇: ALAC(Act-like-a-cust