好牛!抖音开源又一力作,


大家都喜欢玩抖音,知道抖音是一个非常好的技术团队,除了做App,他们也开源了一些方案,比如今天的 BoostMultiDex 。

BoostMultiDex是一个用于 Android 低版本设备(4.X 及以下,SDK < 21)快速加载多 DEX 的解决方案。

背景

我们知道,Android低版本(4.X及以下,SDK < 21)的设备,采用的Java运行环境是Dalvik虚拟机。它相比于高版本,最大的问题就是在安装或者升级更新之后,首次冷启动的耗时漫长。

这是非常影响用户的使用体验的。尤其在海外,像东南亚以及拉美等地区,还存有着很大量的低端机。4.X以下低版本用户虽然比较少,但对于抖音及Tiktok这样有着亿级规模的用户的APP,即使占比10%,数目也有上千万。因此如果想要打通下沉市场,这部分用户的使用和升级体验是绝对无法忽视的。

这个问题的根本原因就在于,安装或者升级后首次MultiDex花费的时间过于漫长。为了解决这个问题,我们挖掘了Dalvik虚拟机的底层系统机制,对DEX相关处理逻辑进行了重新设计,最终推出了BoostMultiDex方案,挽救低版本Android用户的升级安装体验。

技术要点

BoostMultiDex方案的技术实现要点如下:

更重要的是,BoostMultiDex已经在抖音/TikTok亿级全球用户上验证通过,可以说涵盖了各个国家、各种复杂情况的Android机型,目前业界其他大型APP都很难涉及到如此广泛的规模。由此,我们也解决了各种奇怪的兼容性问题,最大程度上确保了技术方案的稳定性。

快速接入

build.gradle的dependencies中添加依赖:

  1. dependencies { 
  2. ... ... 
  3.     // For specific version number, please refer to app demo 
  4.     implementation 'com.bytedance.boost_multidex:boost_multidex:${ARTIFACT_VERSION}' 

与官方MultiDex类似,在Application.attachBaseContext的最前面进行初始化即可:

  1. public class YourApplication extends Application { 
  2.  
  3.     @Override 
  4.     protected void attachBaseContext(Context base) { 
  5.         super.attachBaseContext(base); 
  6.          
  7.         BoostMultiDex.install(base); 
  8.          
  9. ... ... 
  10.     } 

编译构建

如果想自行编译打包,需要使用R16B版本的NDK以支持armeabi架构,如果不需要,可以直接在boost_multidex/build.gradle中去掉此依赖。

执行以下命令即可构建本地aar包:

  1. ./gradlew :boost_multidex:assembleRelease 

产物为 boost_multidex/build/outputs/aar/boost_multidex-release.aar

性能对比

以上是在抖音上测得的实际数据,APK中共有6个Secondary DEX,显而易见,BoostMultiDex方案相比官方MultiDex方案,其耗时有着本质上的优化,基本都只到原先的11%~17%之间。 也就是说BoostMultiDex减少了原先过程80%以上的耗时。 另外我们看到,其中有一个机型,在官方MultiDex下是直接崩溃,无法启动的。使用BoostMultiDex也将使得这些机型可以焕发新生。

性能对比如下:

项目地址: https://github.com/bytedance/BoostMultiDex

相关内容