fastdex

Project Url: typ0520/fastdex
Introduction: 加快 apk 的编译速度
More: Author   ReportBugs   
Tags:
fastdex-加快android打包速度-android studio-加快android studio编译速度-加快apk的编译速度-

license Download

如果你忍受不了 apk 龟速的编译(尤其是项目中有多个 dex),fastdex 可以帮助你加快 apk 生成过程

fastdex.png

Android API 9(2.3)+ ; android-gradle-build 2.0.0+

版本记录

使用方式

idea 插件

在 Android Studio 中,打开搜索插件页面:

  • MacOS

    Android Studio → Preferences → Plugins → Browse repositories

  • Windows 和 Linux

    File → Settings → Plugins → Browse repositories

搜索 fastdex 安装重启 Android Studio 就可以了。

手动配置

  • 1、关闭 Instant Run 功能 点击左上角 Android studio -> Preferences -> Build,Execution,Deployment -> Instant Run -> Enable Instant Run......(把对勾去掉)

  • 2、在 root project 下的 build.gradle 中添加依赖

    ````
    buildscript {
      repositories {
          jcenter()
      }
    
      dependencies {
          classpath 'com.github.typ0520:fastdex-gradle:0.8.6'
      }
    

    }

     ````
    
  • 3、在 app 的项目中的 build.gradle 添加插件

      apply plugin: 'fastdex.app'
    
  • 4、直接点击 studio 的 run 或者执行打包命令,就会在任务执行的过程中做 hook

      第一次全量打包成功后,fastdex 支持把增量的 dex 和资源推送到正在运行的 app 里重启并加载,这样会省去安装 app 的时间开销
      拿 debug 为例如果没有配置 flavor 就执行(gradlew fastdex${Variant})
    
      Mac/Linux:
      ./gradlew fastdexDebug
    
      Windows:
      gradlew.bat fastdexDebug
    

注意事项

  • 1、不要把 fastdex 打出来的包用在生产环境,因为 fastdex 打出来的包项目所有的代码都在第二个 dex 后面,会造成 5.0 以 下机器首次运行比较慢(如果是本地调试就无所谓了);当打包生产环境 apk 时注释掉加入插件的代码 //apply plugin: 'fastdex.app'

  • 2、fastdex 会忽略开启混淆的 buildType

  • 3、强烈建议你的 application 不要直接依赖 library 工程,打成 aar 包让 application 工程远程依赖

实现原理

  • gradle 在执行 transformClassesWithDexFor${variant}任务生成 dex 文件时会很慢(尤其是开启了 multidex),我们在开发中,修改的几乎全是项目代码,第三方库改动比较小。fastdex 的原理就是预先把所有代码生成 dex, 当下次执行 assemble 任务时只会把项目目录下变化的代码生成 dex,然后和缓存的 dex 合并生成 apk,这样即不影响调试,又能在生成 dex 的过程中省下了大量的时间。 详情

  • 应用安装的速度比较慢,尤其是 5.0 以后的版本,fastdex 会把补丁 dex 和资源通过 adb 推到正在运行的 app 里直接重启 app

打包流程

全量打包时的流程:
  • 1、合并所有的 class 文件生成一个 jar 包
  • 2、扫描所有的项目代码并且在构造方法里添加对 fastdex.runtime.antilazyload.AntilazyLoad 类的依赖 这样做的目的是为了解决 class verify 的问题, 详情请看 安卓 App 热补丁动态修复技术介绍
  • 3、对项目代码做快照,为了以后补丁打包时对比那些 java 文件发生了变化
  • 4、对当前项目的所以依赖做快照,为了以后补丁打包时对比依赖是否发生了变化,如果变化需要清除缓存
  • 5、调用真正的 transform 生成 dex
  • 6、缓存生成的 dex,并且把 fastdex-runtime.dex 插入到 dex 列表中,假如生成了两个 dex,classes.dex classes2.dex 需要做一下操作 fastdex-runtime.dex => classes.dex classes.dex => classes2.dex classes2.dex => classes3.dex 然后运行期在入口 Application(fastdex.runtime.FastdexApplication)使用 MultiDex 把所有的 dex 加载进来
  • @see fastdex.build.transform.FastdexDexTransform
  • 7、保存资源映射表,为了保持 id 的值一致,详情看
  • @see fastdex.build.task.FastdexResourceIdTask
补丁打包时的流程
  • 1、检查缓存的有效性
  • @see fastdex.build.variant.FastdexVariant 的 prepareEnv 方法说明
  • 2、扫描所有变化的 java 文件并编译成 class
  • @see fastdex.build.task.FastdexCustomJavacTask
  • 3、合并所有变化的 class 并生成 jar 包
  • 4、生成补丁 dex
  • 5、把所有的 dex 按照一定规律放在 transformClassesWithMultidexlistFor${variantName}任务的输出目录 fastdex-runtime.dex => classes.dex patch.dex => classes2.dex dex_cache.classes.dex => classes3.dex dex_cache.classes2.dex => classes4.dex dex_cache.classesN.dex => classes(N + 2).dex

Thanks

Instant Run

Tinker

Freeline

安卓 App 热补丁动态修复技术介绍

Android 应用程序资源的编译和打包过程分析

Apps
About Me
GitHub: Trinea
Facebook: Dev Tools