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

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

Android系統在安裝應用時,往往需要優化Dex,而由於處理工具DexOpt對id數目的限制,導致其處理的數目不能超過65536個,因此在Android開發中,需要使用到MultiDex來解決這個問題,MultiDex可以配合Android Studio實現一個apk包含多個dex的功能,現在就讓我們來看看MultiDex究竟是怎麼一回事?

 

1、MultiDex的工作原理

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

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

2、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時,並收到了這個錯誤,那麼表示你有很多代碼!爲什麼會出現這個問題,而這個問題又怎麼解決呢?且看下面分析。

3、關於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文件和它們所包含的代碼。

4、避免65K限制

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

去掉一些未使用的import和library

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

5、用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的繼承方式做一個修改。

6、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.com

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章