在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
当然,也有一些系统设备会出现以下log信息,不过反馈的都是同一个问题:
trouble writingoutput: Too many field references:
这两个错误条件显示一个共同的数字: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
在manifest文件中,添加MultidexApplication Class的引用,IT蓝豹为你演示:
"1.0"encoding=
当然,如果重写了 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