概念
Dalvik 是运行Android程序的虚拟机,是Google等厂商合作开发的Android移动设备平台的核心组成部分之一。Dalvik允许在优先的内存中同时运行多个虚拟机实例,每个应用作为一个独立的linux进程。Dalvik支持运行.dex格式的Java引用程序(dex格式专为Dalvik设计的一种压缩格式,适用于内存和处理器有限的系统)。Android系统中的安装包APK(Android Package),其实就是dex字节码和资源配置文件压缩而成。dex全称Dalvik VM Executes。
ART全称Android Runtime,是Android所使用的一种新的虚拟机,有Google研发,并在Android 4.4中新增的,并在Android 5.0及以后的版本中替代Dalvik。ART不在使用DEX文件,而是OAT格式文件,在重启过程中,系统会完成从DEX到OAT格式的转换。
区别
Dalvik依靠一个Just-In-Time编译器去解释字节码,应用程序需要通过一个解释器进行转换后再执行,并不高效但是更容易适配不同硬件和架构。ART则是在应用安装时就预编译字节码到机器语言,称之为Ahead-of-Time(AOT)编译,程序执行更高效,但是安装速度降低,同时占用更大的存储空间(编译后代码)。
Android dex分包
当Android虚拟机采用Dex格式应用时,如果应用足够大的时候可能会遇到一个问题:Too many method references: 70048; max is 65536,就是我们常说的65536问题。
65536是什么东西呢?当Android系统在运行应用的时候,首先会将应用的代码压缩文件dex文件优化加载到内存中,即把dex文件中的每一个类方法检索起来,存在一个链表结构里面,但是这个链表的长度用一个short类型来保存,当方法数目超过short的最大值65536的时候就会出现这个问题,应用方法过多无法加载到内存中。
另外,在Android 2.3及以前的版本中,执行dexopt(优化dex文件)只分配了5M空间,安装可能出现INSTALL_FAILED_DEXOPT。
上述问题,目前主要有两种解决方案Android dex分包技术和Android 插件化技术。dex分包技术是指通过将编译好的class文件打包成两个或多个dex文件,然后运行时在动态加载把需要的dex加载到内存中。分包技术Android已经提供了MultiDex支持,介绍使用参考官方文档
https://developer.android.com/reference/android/support/multidex/MultiDex.html
https://developer.android.com/studio/build/multidex.html#avoid