Gradle 提速:每天为你省下一杯喝咖啡的时间

Stella981
• 阅读 1353

摘要: ### 前言 作为一名 Android 开发同学,当你的工程和代码达到一定规模的时候,相信你一定遇到过编译速度过慢的问题。比如: ![](https://user-gold-cdn.xitu.io/2018/11/6/166e7021c081493c?w=300&h=227&f=gif&s=1226695) 等待编译的时间,仿佛过了一个世纪,有没有! 对于程序猿,时间尤其宝贵,

前言

作为一名 Android 开发同学,当你的工程和代码达到一定规模的时候,相信你一定遇到过编译速度过慢的问题。比如:

Gradle 提速:每天为你省下一杯喝咖啡的时间

等待编译的时间,仿佛过了一个世纪,有没有!

对于程序猿,时间尤其宝贵,当你修改完一个 BUG 或者想验证一个功能时,却因为编译速度过慢而不得不打断你的思路,也会严重影响你的开发效率。

正所谓,磨刀不误砍柴工,所以,减少和提升你工程的编译速度是一个值得立刻开始的重要工作。

如何优化

Gradle 官方的一些优化建议

  1. 尽可能的使用最新版本的 Gradle 和 JVM,这是最简单直接的方式,Gradle 开发团队会持续的更新 Gradle 版本,来优化构建速度以及提供一些新的特性,而使用新版本的 JVM,是因为 Gradle 运行在 JVM 上,所以,如果新版本的 JVM 提升了性能,同样也会让 Gradle 跑的更快。

  2. Parallel execution,并行执行 Gradle 的 tasks,在你的 gradle.properties 文件添加以下配置:

        org.gradle.parallel=true
    
  3. Build Scan,是一个很好的诊断工具,通过该工具可以很好的帮助你去分析和解决编译速度慢的问题。
    Gradle 提速:每天为你省下一杯喝咖啡的时间

使用方法:在你的 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)
  1. 配置阶段

    • 减少不必要的 apply plugin,按需使用。如果某个插件不是所有的模块都要使用的情况下,就不要使用 allprojects{} 的方式。
    • 在配置阶段避免执行一些耗时的工作,比如 IO 操作或者网络请求等
  2. 依赖解析

    • 减少动态 (2.+) 版本和 SNAPSHOT 版本的依赖库,通常这种方式的依赖,会强制 Gradle 去远端仓库比对是否有新的变化。
    • 避免不必要和未使用的依赖
  3. 任务执行阶段

  4. Daemon

    • 在老版本的 Gradle 开启 Daemon 配置,而在 3.0 以后的 Gradle 版本是默认支持的。

    • 调整 daemon’s 的堆大小,默认是 1 GB,如需调大,可在你的 gradle.properties 设置:

          org.gradle.jvmargs=-Xmx2048M
      
  5. 使用 implementation 替代 compile,有效的减少编译时的依赖项,需升级至 Gradle 3.4 版本

  6. 增量编译,Gradle 可以将依赖关系分析到单个类级别,以便仅重新编译受更改影响的类。 增量编译是 Gradle 4.10 以来的默认编译。 在老的版本中,可以像这样激活它:

    tasks.withType(JavaCompile) {
        options.incremental = true
    }
    
  7. 使用分析报告,通过以下命令可以在编译完成后,生成一份本地的分析报告:

    ./gradlew assembleDebug --profile
    

Gradle 提速:每天为你省下一杯喝咖啡的时间

Android 官方的一些优化建议

  1. 使用最新版本的工具

  2. 避免编译不必要的资源,比如不必要的语言本地化,
    你可以只指定一种语言资源和屏幕适配,如以下示例所示:

    android {
      ...
      productFlavors {
        dev {
          ...
          // The following configuration limits the "dev" flavor to using
          // English stringresources and xxhdpi screen-density resources.
          resConfigs "en", "xxhdpi"
        }
        ...
      }
    }
    
  3. 开启离线模式

    ![](https://user-gold-cdn.xitu.io/2018/11/6/166e8123654236ee?w=1584&h=506&f=png&s=74335)
    
  4. 开启按需配置

    ![](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 已被移除
    
  5. 使用 WebP 格式的图片,有效减少图像文件大小,而不必执行构建时压缩,可以加快你的构建

  6. 关闭 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
    // }
    }

  7. 开启 Instant Run

    ![](https://user-gold-cdn.xitu.io/2018/11/6/166e823fa2f75df0?w=1178&h=432&f=png&s=65707)
    

最后说几句

其实,有些同学不太重视也不太愿意花精力去折腾这些,想着忍忍也就过去了。但是,随着编译次数的增加,实际所浪费的时间远超出你想象,而从提升团队生产力的角度来看的话,这是一个投入产出比相当高的事情,以本人所参与的一个项目为例,优化后比优化前的构建时间减少了 50%,多出一个喝咖啡的时间还是很轻松的,而整个团队节省下来的时间,可以 code review,可以去学习,可以早点下班,总之,都比你在边等待构建边发呆好!

参考文档

Optimize your build speed

[Improving the Performance of Gradle Builds
](https://guides.gradle.org/performance/)

[How to decrease your Gradle build time by 65%?
](https://medium.com/exploring-code/how-to-decrease-your-gradle-build-time-by-65-310b572b0c43)

原文链接

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Android So动态加载 优雅实现与原理分析
背景:漫品Android客户端集成适配转换功能(基于目标识别(So库35M)和人脸识别库(5M)),导致apk体积50M左右,为优化客户端体验,决定实现So文件动态加载.!(https://oscimg.oschina.net/oscnet/00d1ff90e4b34869664fef59e3ec3fdd20b.png)点击上方“蓝字”关注我
Stella981 Stella981
3年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这