Android学习笔记----解决“com.android.dex.DexIndexOverflowException: method ID not in [0, 0xffff]: 65536”问题

同时在工程中引入了多个第三方jar包,致使调用的方法数超过了android设定的65536个(DEX 64K problem),进而致使dex没法生成,也就没法生成APK文件。java

解决办法以下:android

一、谷歌官方已经给出了相关的文档,参照网上搜索的资料,首先,个人问题是:ide

Error:Execution failed for task ':duchazhushou:dexRelease'.
> com.android.ide.common.internal.LoggedErrorException: Failed to run command:
    C:\Users\jeff\AppData\Local\Android\sdk\android-sdk\build-tools\21.1.1\dx.bat --dex --output D:\dev\android\Duchazhushou_TDT\duchazhushou\build\intermediates\dex\release --input-list=D:\dev\android\Duchazhushou_TDT\duchazhushou\build\intermediates\tmp\dex\release\inputList.txt
Error Code:
    2
Output:
    UNEXPECTED TOP-LEVEL EXCEPTION:
    com.android.dex.DexIndexOverflowException: method ID not in [0, 0xffff]: 65536
        at com.android.dx.merge.DexMerger$6.updateIndex(DexMerger.java:502)
        at com.android.dx.merge.DexMerger$IdMerger.mergeSorted(DexMerger.java:277)
        at com.android.dx.merge.DexMerger.mergeMethodIds(DexMerger.java:491)
        at com.android.dx.merge.DexMerger.mergeDexes(DexMerger.java:168)
        at com.android.dx.merge.DexMerger.merge(DexMerger.java:189)
        at com.android.dx.command.dexer.Main.mergeLibraryDexBuffers(Main.java:454)
        at com.android.dx.command.dexer.Main.runMonoDex(Main.java:302)
        at com.android.dx.command.dexer.Main.run(Main.java:245)
        at com.android.dx.command.dexer.Main.main(Main.java:214)
        at com.android.dx.command.Main.main(Main.java:106)

二、在项目的build.gradle文件的dependencies 节中添加分包设置:gradle

dependencies { 
... 
   compile 'com.android.support:multidex:' 
   ... 
}

三、经过在defaultConfig节中设置multiDexEnabled标签为true,开启multi-dexing支持.ui

defaultConfig { 
   ... 
multiDexEnabled true 
... 
}

四、分三种状况,因为我并未建立本身的Application.class,直接在AndroidManifest.xml文件的Application声明中添加;spa

android:name="android.support.multidex.MultiDexApplication"

五、从新build,生成签名APK,安装使用正常。code

以上步骤均参考下面连接操做,关于第4步的另外两种状况,在下面连接中均有详细说明:xml

http://stackoverflow.com/questions/27377080/after-update-of-as-to-1-0-getting-method-id-not-in-0-0xffff-65536-error-iblog