fastdex

项目地址:typ0520/fastdex
简介:加快 apk 的编译速度
更多:作者   提 Bug   
标签:
fastdex-加快android打包速度-android studio-加快android studio编译速度-加快apk的编译速度-

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

license

Download

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

版本记录

使用方式

  • 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.2.0'
          }
      }
    
  • 3、在 app 的项目中的 build.gradle 添加插件

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

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

注意事项

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

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

  • 3、强烈建议你的 application 不要直接依赖 library 工程,打成 aar 包让 application 工程远程依赖,目前还没有做充分测试

  • 4、开启自定义的编译任务能获得更快的构建速度(这个特性目前不支持使用 lambda),对使用了 butterknife 的大型项目效果最明显,这一特性目前还不稳定 0.0.3-beta3 后默认关闭了,使用了,如果想尝试在 build.gradle 中加入下面配置

    fastdex {
        useCustomCompile = true
    }
    

实现原理

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

详情

打包流程

全量打包时的流程:
  • 1、合并所有的 class 文件生成一个 jar 包
  • 2、扫描所有的项目代码并且在构造方法里添加对 com.dx168.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(com.dx168.fastdex.runtime.FastdexApplication)使用 MultiDex 把所有的 dex 加载进来
  • @see com.dx168.fastdex.build.transform.FastdexTransform
  • 7、保存资源映射表,为了保持 id 的值一致,详情看
  • @see com.dx168.fastdex.build.task.FastdexResourceIdTask
补丁打包时的流程
  • 1、检查缓存的有效性
  • @see com.dx168.fastdex.build.task.FastdexCustomJavacTask 的 prepareEnv 方法说明
  • 2、扫描所有变化的 java 文件并编译成 class
  • @see com.dx168.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

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

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

Android 开发经验分享
用了一年多的理财推荐
Android 开发经验分享
用了一年多的理财推荐