本文共 3002 字,大约阅读时间需要 10 分钟。
作为一名 Android 开发同学,当你的工程和代码达到一定规模的时候,相信你一定遇到过编译速度过慢的问题。比如:
等待编译的时间,仿佛过了一个世纪,有没有!
对于程序猿,时间尤其宝贵,当你修改完一个 BUG 或者想验证一个功能时,却因为编译速度过慢而不得不打断你的思路,也会严重影响你的开发效率。
正所谓,磨刀不误砍柴工,所以,减少和提升你工程的编译速度是一个值得立刻开始的重要工作。
Parallel execution,并行执行 Gradle 的 tasks,在你的 gradle.properties
文件添加以下配置:
org.gradle.parallel=true
使用方法:在你的 Gradle 构建工程里执行以下命令
./gradlew build --scan
> 需要注意的是,Build Scan 是高版本的 Gradle(4.3+) 默认才有的功能,针对低版本(4.3以下)的 Gradle 需要额外安装一个插件才可以使用,具体信息可以点击:[Build Scan Plugin User Manual](https://docs.gradle.com/build-scan-plugin/?&_ga=2.100043736.79666310.1541473383-2130798346.1527486300#getting_set_up)
配置阶段
apply plugin
,按需使用。如果某个插件不是所有的模块都要使用的情况下,就不要使用 allprojects{}
的方式。依赖解析
任务执行阶段
Daemon
调整 daemon’s 的堆大小,默认是 1 GB,如需调大,可在你的 gradle.properties
设置:
org.gradle.jvmargs=-Xmx2048M
implementation
替代 compile
,有效的减少编译时的依赖项,需升级至 Gradle 3.4 版本增量编译,Gradle 可以将依赖关系分析到单个类级别,以便仅重新编译受更改影响的类。 增量编译是 Gradle 4.10 以来的默认编译。 在老的版本中,可以像这样激活它:
tasks.withType(JavaCompile) { options.incremental = true}
使用分析报告,通过以下命令可以在编译完成后,生成一份本地的分析报告:
./gradlew assembleDebug --profile
使用最新版本的工具
android { ... productFlavors { dev { ... // The following configuration limits the "dev" flavor to using // English stringresources and xxhdpi screen-density resources. resConfigs "en", "xxhdpi" } ... } }
开启离线模式,
![](https://user-gold-cdn.xitu.io/2018/11/6/166e8123654236ee?w=1584&h=506&f=png&s=74335)
开启按需配置
![](https://user-gold-cdn.xitu.io/2018/11/6/166e819b7cbbde69?w=1766&h=758&f=png&s=189902)> 注意一:如果你使用的是 Gradle 4.6 版本,而 `com.android.tools.build:gradle` 版本是 3.0.1 或者 3.1.0,你需要禁用该配置以避免一些不必要的问题,该问题会在将来的 Android Gradle 插件版本中被修复> 注意二:在最新的 Android Studio 版本中,configuration on demand 已被移除
关闭 PNG crunching,加快构建速度通过禁用自动图像压缩,Gradle 3.0 版本以上在 debug
的构建类型下是默认关闭的。如需手动配置其他构建类型,如下示例:
android {
buildTypes { release { // Disables PNG crunching for the release build type. crunchPngs false }}
// If you're using an older version of the plugin, use the
// following:// aaptOptions { // cruncherEnabled false// }}开启 Instant Run
![](https://user-gold-cdn.xitu.io/2018/11/6/166e823fa2f75df0?w=1178&h=432&f=png&s=65707)
其实,有些同学不太重视也不太愿意花精力去折腾这些,想着忍忍也就过去了。但是,随着编译次数的增加,实际所浪费的时间远超出你想象,而从提升团队生产力的角度来看的话,这是一个投入产出比相当高的事情,以本人所参与的一个项目为例,优化后比优化前的构建时间减少了 50%,多出一个喝咖啡的时间还是很轻松的,而整个团队节省下来的时间,可以 code review,可以去学习,可以早点下班,总之,都比你在边等待构建边发呆好!
[Improving the Performance of Gradle Builds
]([How to decrease your Gradle build time by 65%?
](转载地址:http://rbgjx.baihongyu.com/