在Android项目开发中,项目代码量过大或经过引入不少jar致使代码量急剧增长,会出现错误:html
android.dex.DexIndexOverflowException: Cannot merge new index xxxx into a non-jumbo instruction!
错误出现的缘由是 Android设定的方法数是65536个(DEX 64K problem),超过这个方法数,致使dex没法生成,就没法生成APK.java
限制缘由: 早期的Dalvik VM内部使用short类型变量来标识方法的id,就有了 最大方法数的限制65536。android
解决方法:git
删除不用的方法,删除不使用的jar。github
分包
经过在defaultConfig中设置multiDexEnabled开启分包模式,分包以后的Dex就低于了限制数,保证了正常的打包。segmentfault
1 defaultConfig { 2 multiDexEnabled=true 3 }
1 android.dexOptions { 2 jumboMode = true 3 }
设置dexOptions的,不作方法数限制的检查,这样作的缺点是apk没法再低版本的设备上面安装,会出现错误:gradle
INSTALL_FAILED_DEXOPT
关于dexoptions
和jumboMode
在stackoverflow中有一段描述:ui
In the standard java world:this
When you compile standard java code : the compiler produce *.class
file. A *.class
file contains standard java bytecode that can be executed on a standard JVM.google
In the Android world:
*.class
files, it produce *.dex
file. A *.dex
file contains bytecode that can be executed on the Android Virtual Machine (dalvik) and this is not a standard Java Virtual Machine.dexoptions
is a gradle object where some options to configure this java-code-to-android-bytecode transformation are defined. The options configured via this object are :
在标准Java的世界
当编译java代码时,编译器生成.class
文件。.class
文件包含了java的字节码。这些字节码在JVM中执行。
在安卓的世界则不一样:
.dex
文件,不是.java
文件。.dex
文件包含了在Android虚拟机中能够执行的字节码,而不是JVM。因此.dex
文件的做用和标准Java中的.class文件差很少。dexoptions
是一个gradle对象,这个对象用来设置从java代码向.dex文件转化的过程当中的一些配置选项。其中一个就是force-jumbo mode。force-jumbo mode容许你建立更大的.dex
文件。参考资料: