一、
1、如果App引用的库太多,方法数超过65536后无法编译。这是因为单个dex里面不能有超过65536个方法。
2、 因为android会把每一个类的方法id检索起来,存在一个链表结构里面。但是这个链表的长度是用一个short类型来保存的, short占两个字节(保存-2的15次方到2的15次方-1,即-32768~32767),最大保存的数量就是65536。
3、新版本的Android系统中修复了这个问题, 但是我们仍然需要对低版本的Android系统做兼容。
Android 5.0(API leve 21
二、分割dex
dex文件拆成两个或多个,为此谷歌官方推出了multidex兼容包,配合AndroidStudio实现了一个APK包含多个dex的功能
注意事项:Application 中的静态全局变量会比MutiDex的 install()方法优先加载,所以建议避免在Application类中使用静态变量引用 main classes.dex文件以外dex文件中的类。
实现原理
下面从DEX自动拆包和动态加载两方面来分析。
Dex 拆分
dex拆分步骤分为:
自动扫描整个工程代码得到main-dex-list;
根据main-dex-list对整个工程编译后的所有class进行拆分,将主、从dex的class文件分开;
用dx工具对主、从dex的class文件分别打包成 .dex文件,并放在apk的合适目录。
Dex加载
因为Android系统在启动应用时只加载了主dex(Classes.dex),其他的 dex 需要我们在应用启动后进行动态加载安装。 Google 官方方案是如何加载的呢,Google官方支持Multidex 的 jar 包是 android-support-multidex.jar,该 jar 包从 build tools 21.1 开始支持。