在android開發中使用multdex的方法-IT藍豹爲你整理

在android開發中使用multdex的方法-IT藍豹爲你整理

Android系統在安裝應用時,每每須要優化Dex,而因爲處理工具DexOpt對id數目的限制,致使其處理的數目不能超過65536個,所以在Android開發中,須要使用到MultiDex來解決這個問題,MultiDex能夠配合Android Studio實現一個apk包含多個dex的功能,如今就讓咱們來看看MultiDex到底是怎麼一回事?

 

一、MultiDex的工做原理

關於這個問題,以APK中有兩個dex文件爲例,第二個dex文件爲classes2.dex。

在 Android應用安裝中,兼容包在Applicaion實例化以後,會檢查系統版本是否支持 multidex,classes2.dex是否須要安裝,若是須要安裝則會從APK中解壓出classes2.dex並將其拷貝到應用的沙盒目錄下。通 過反射將classes2.dex注入到當前的classloader中。

二、APP的函數方法超過65K

隨着Android設備的發展,App包含的功能將愈來愈完善,其大小勢必會變得愈來愈大。當在開發App的時候因爲報的大小和引用庫的緣由,編譯項目時候一般會遇到下面這個錯誤:

Conversion <spanclass="hljs-keyword">to</span> Dalvik format failed: Unable<span class="hljs-keyword">to</span> execute dex:<span class="hljs-function"><span class="hljs-keyword">method</span><span class="hljs-title">ID</span> <spanclass="hljs-title">not</span> <spanclass="hljs-title">in</span> [0, 0<spanclass="hljs-title">xffff</span>]:</span> <spanclass="hljs-number">65536</span>

固然,也有一些系統設備會出現如下log信息,不過反饋的都是同一個問題:

trouble writingoutput: Too many field references: <spanclass="hljs-number">131000</span>; <spanclass="hljs-built_in">max</span> is <spanclass="hljs-number">65536.</span> You may <spanclass="hljs-keyword">try</span> <spanclass="hljs-keyword">using</span> <spanclass="hljs-comment">--multi-dex option.</span>

這兩個錯誤條件顯示一個共同的數字:65536。這個數字,它表示的是你在一個dex包中的函數方法超過了65535個。

若是你已經構建了一個AndroidApp時,並收到了這個錯誤,那麼表示你有不少代碼!爲何會出現這個問題,而這個問題又怎麼解決呢?且看下面分析。

三、關於65K方法限制

Android開發人員應該都清楚,Android的全部可執行文件都存在dex文件中,其中包含已編譯的代碼來運行你的應用程序。Dalvik虛擬機對可執行dex文件的規格是有方法限制的,即一個單一的dex文件的方法總數最多爲65536,包括:

引用的Android Framework方法、library的方法及編程中寫入代碼的方法等。

怎麼突破限制呢?很簡單,就是多生成幾個dex文件,而這個多個dex文件,就是multidex方案配置。

Multidex支持Android 5.0以前使用Dalvik Runtime執行程序代碼的版本。默認狀況下,限制應用到一個單一的classes.dex。

Dalvik字節碼文件沒APK,爲了繞過這個限制,你可使用multidex支持庫,成爲你的應用程序的主要部分,以及對DEX文件進行管理並得到額外的dex文件和它們所包含的代碼。

四、避免65K限制

當肯定使用multidex的分包策略時,除了確保你的代碼是優秀的代碼之外,還須要作到如下兩個步驟:

去掉一些未使用的import和library

使用ProGuard去掉一些未使用的代碼

五、用Gradle配置使用Multidex

Android 的 Gradle插件在 Android Build Tool 21.1開始就支持使用multidex了。

在應用程序中設置multidex配置,須要對對程序作如下修改:

修改Gradle的配置,支持multidex

修改你的manifest。讓其支持multidexapplication類

修改Gradle的build以下:

android { compileSdkVersion <spanclass="hljs-number">21</span> buildToolsVersion <spanclass="hljs-string">"21.1.0"</span> defaultConfig { <spanclass="hljs-keyword">...</span> minSdkVersion <span class="hljs-number">14</span> targetSdkVersion <spanclass="hljs-number">21</span> <spanclass="hljs-keyword">...</span> // Enabling multidex support. multiDexEnabled true } <span class="hljs-keyword">...</span> } dependencies { compile <spanclass="hljs-string">'com.android.support:multidex:1.0.0'</span>}

在manifest文件中,添加MultidexApplication Class的引用,IT藍豹爲你演示:

<?xmlversion=<span class="hljs-string">"1.0"</span>encoding=<spanclass="hljs-string">"utf-8"</span>?><manifest xmlns:android=<spanclass="hljs-string">"http://schemas.android.com/apk/res/android"</span> package=<spanclass="hljs-string">"com.example.android.multidex.myapplication"</span>> <application <spanclass="hljs-keyword">...</span> android:name=<spanclass="hljs-string">"android.support.multidex.MultiDexApplication"</span>> <spanclass="hljs-keyword">...</span> </application> </manifest>

固然,若是重寫了 Application,就對自定義Application的繼承方式作一個修改。

六、Multidex的方式的侷限性

在上面的介紹中,multidex看起來感受很棒,雖然如此,但multidex仍是存在一些侷限性,具體以下:

(1)若是DEX文件太大,安裝分割dex文件是一個複雜的過程,可能會致使應用程序無響應(ANR)的錯誤。在這種狀況下,你應該儘可能的減少dex文件的大小和刪除無用的邏輯,而不是徹底依賴於multidex。

(2) 在Android 4.0設備(API Level 14)以前,因爲Dalvik linearalloc bug(問題22586),multidex極可能是沒法運行的。若是但願運行在Level 14以前的Android系統版本,請先確保完整的測試和使用。

(3)應用程序使用了multiedex配置的,會形成使用比較大的內存。固然,可能還會引發dalvik虛擬機的崩潰(issue 78035)。

(4)對於應用程序比較複雜的,存在較多的library的項目。multidex可能會形成不一樣依賴項目間的dex文件函數相互調用,找不到方法。

以上即是關於MultiDex的原理及使用方法的簡單介紹,若是在Android開發中,遇到65K方法限制,能夠嘗試使用MultiDex來解決。


本文做者:《IT藍豹》:www.itlanbao.comandroid

相關文章
相關標籤/搜索