Android分包方案multidex

前言

当方法数超过65536的时候,就会出现方法数越界

情况一

不包括框架,jar包,项目中的java代码的方法数超过了65536,使用AS打包,直接提示异常,无法打包

情况二

包括框架、jar包以及java代码,方法数超过了65536。AS打包的时候 ,如果不进行Multidex处理,是打不成apk包的。

有时候,一些游戏并不是用android studio打的apk包。如果里面的java代码超过了65536也会出现方法数越界的问题。但现在一些比较高版本的手机并不会闪退,低版本的才会出现问题。
原因:高版本手机修复了此问题

情况三

即使方法数没有超过65536,在低版本的手机安装apk的时候,也会出现安装不了的情况。

原因:dexopt(dex optimization dex文件优化程序),优化过程中,它使用的缓冲区(用来存储方法信息的)大小超过了手机所能提供的限制5M。如今高版本改成了8M。
扩展:dexopt是优化apk中的dex文件,优化后生成了一个odex文件。作用是加速app的运行速度,减少对ram的占用。

其实网上关于解决multidex的方法很多了,我就不赘述了。

使用MultiDex存在的一些问题

1.出现找不到Application类的静态全局变量的闪退bug。

Application中的静态全局变量会比Multidex的install方法优先加载,所以建议避免在Application类中使用静态变量引用main classes.dex文件以外dex文件中的类。
通过gradle,可以显示的把一些类放在main dex中。

afterEvaluate {
    tasks.matching {
        it.name.startsWith('dex')
    }.each { dx ->
        if (dx.additionalParameters == null) {
            dx.additionalParameters = []
        }
        dx.additionalParameters += '--multi-dex'
        dx.additionalParameters += "--main-dex-list=$projectDir/".toString()
    }
}

注意上面是修改后的Gradle,其中是一个文本文件的文件名,存放在和这个build.gradle脚本同一级的文件目录下,而不是 项目根目录。可以把这个文本文件起名为multidex.keep,内容如下.实际就是把需要放在Main Dex的类罗列出来.
android/support/multidex/BuildConfig/class
android/support/multidex/MultiDex$V14/class
android/support/multidex/MultiDex$V19/class
android/support/multidex/MultiDex$V4/class
android/support/multidex/MultiDex/class
android/support/multidex/MultiDexApplication/class
android/support/multidex/MultiDexExtractor$1/class
android/support/multidex/MultiDexExtractor/class
android/support/multidex/ZipUtil$CentralDirectory/class
android/support/multidex/ZipUtil/class

project.afterEvaluate标签在特定的project配置完成后运行,而gradle.projectsEvaluated在所有projects配置完成后运行。 注意afterEvaluate需要放在android{}里,不可放外面。

但是最新的as中,会自动判断依赖关系来分dex,比如以下application中:
public class MyApp extends MultiDexApplication {

public static MutilTest5 mutilTest5 = new MutilTest5();

@Override
public void onCreate() {
    super.onCreate();
}

}
默认情况下,本来MuitlText5要分到class2.dex里面去,但是因为app里静态变量需要用到MuitlText5,如果放到class2.dex中会找不到(因为app中静态变量初始化会在加载主dex文件之前执行),所以会自动放到主dex文件里去
但是如果依靠as自动分析,在你代码存在反射和native的情况下,也不保证100%正确,如果不正确,还是需要自己配置哪个类放到主dex中

2.还可以把指定类放到第二个dex中去。

参考文章

http://www.cnblogs.com/chenxibobo/p/6076459.html

你可能感兴趣的:(Android分包方案multidex)