一个APK中包含多个dex方法

原因

每个单独的dex(Dalvik Executable)文件中的方法id范围为[0, 0xffff]:65536,包括安卓系统框架,三方库和自己写得代码中的方法。所以如果你的工程很大,包含了超过65536的方法,那就需要用multiDex技术。

Android 5.0之前和之后的解决方案

在5.0之前所使用的Dalvik运行时默认的一个apk中只能包含一个dex文件。为了解决这个限制,我们可以使用multidex support库,它会成为主dex的一部分,用来取得其它辅助dex文件中的方法。

com.android.support:multidex:1.0.0

在5.0之后,Android改用ART作为运行时,ART天生支持一个APK中包含多个dex文件。因为它在APK安装时,会预先扫描所有的classes(..N).dex文件,把它们编译合成一个.oat的可执行文件。

解决方法

android {
    compileSdkVersion 21
    buildToolsVersion "21.1.0"

    defaultConfig {
        ...
        minSdkVersion 14
        targetSdkVersion 21
        ...

        // Enabling multidex support.
        multiDexEnabled true
    }
    ...
}

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

注意:buildToolsVersion必须为21.1或者更高。

"1.0" encoding="utf-8"?>
"http://schemas.android.com/apk/res/android"
    package="com.example.android.multidex.myapplication">
    ...
        android:name="android.support.multidex.MultiDexApplication">
        ...
    

当以上这些设置后,Android build工具会创建一个主dex和按照需要创建一些辅助的dex(classes2.dex, classes3.dex)。构建系统会把它们一起打包到apk中。

后记

multidex support库还是有些限制的,比如应用可能在Android 4.0之前版本的手机上因为Dalvik linearAlloc bug(Issue 22586)无法运行,也可能会因为multidex配置占用内存分配过大而导致运行奔溃等等。所以运用改技术时需要大量测试。所以最好避免dex限制的方法还是从编写代码时考虑,删除无用引用,用ProGuard做代码优化等等。

参考:
http://developer.android.com/tools/building/multidex.html#dev-build

你可能感兴趣的:(Android那些事儿)