写点什么

[译] 改善 Android Studio 的构建速度 (1),美团移动端开发工程师

用户头像
Android架构
关注
发布于: 刚刚
  • 感谢很多开发者选择在 “preference > data sharing” 中与我们共享他们的使用统计信息,使得这件事情变得可能。

不同的速度测量方式

我们做的第一件事情是使用开源项目(SignalAndroid, Tachiyomi, SantaTracker & skeleton of Uber)来创建内部 benchmark,用于测量各种修改(代码,资源,manifest 等)对于项目构建速度的影响。


例如,这是一个研究代码更改对构建速度影响的 benchmark,可以看出,随着时间的推移,构建速度有很大的改善。



我们还研究了真实的数据,主要关注 Android Gradle 插件升级前后构建调试版本的速度。我们用它来体现新版本上构建速度的实际提升。


这表明了在新版本上,构建速度确实改善了很多,自 2.3 版本以来,构建时间提升了将近 50%。



最后,我们在忽略版本变化的情况下,研究了构建时间随着时间的演变。我们用它来表示实际构建速度随时间的变化。遗憾的是,结果表明了构建速度是随着时间的推移而减慢的。



如果每个版本的构建速度确实越来越快,并且我们可以在数据中看到,那么为什么它们会随着时间的推移而变得越来越慢呢?


我们在更深入的研究之后,意识到在我们的生态系统中发生的事情正在导致构建速度减慢,减慢的速度比我们提升的速度更快。


虽然我们知道随着项目的迭代,代码的增加、资源的使用、语言特性的增加,使项目的构建速度越来越慢,但我们还发现,还有许多其他因素超出了我们的直接控制范围:


  1. 2017 年末的 Spectre 和 Meltdown 补丁对新流程和 I/O 产生了一定影响,使清除构建的速度减慢了 50% 到 140% 之间。

  2. 第三方和客制化的 Gradle 插件:96% 的 Android Studio 开发者使用一些额外的 Gradle 插件(其中一些并没有采用最新的最佳实践)。

  3. 大多数使用的注释处理器都是非增量化的,每次进行编辑时都会导致代码重新全量编译。

  4. 使用 Java 8 语言特性会导致需要执行去语法糖操作,这将影响构建时间。然而,我们已经用 D8 降低了去语法糖操作的影响。

  5. 使用 Kotlin,尤其是 Kotlin(KAPT)中的注释处理,也会影响构建性能。我们将继续与 JetBrains 合作,以将影响降至最低。


  • 和真实的项目不同,那些项目的构建时间不会随着时间的推移而增长。Benchmark 模拟更改,然后撤销更改,仅测量我们的插件随时间推移而受到的影响。

  • 3.3 版本专注于未来改善的基础工作(例如,名称空间资源、增量注释处理器支持、Gradle workers),因此提升了 0%。

我们在做什么?

确定内部流程并持续提升性能。


我们也承认,许多问题来自于谷歌拥有的和推广的功能,我们改变了内部流程,以便在发布过程的早期更好地获得构建反馈。


我们还致力于让注释处理器增量化。截至目前,Glide、Dagger 和 Auto Service 都是增量化的,并且我们还在研究其他的。


在最近的版本中,我们还加入了 R light class generation、lazy task 和 worker API,并继续与 Gradle Inc. 和 JetBrains 合作,以持续改善总体构建性能。


属性工具


最近的一项调查显示,约 60% 的开发者不去分析构建的影响或不知道如何分析。因此,我们希望改善 Android Studio 中的工具,在社区中提高对构建时间影响的意识和透明度。


我们正在探索如何在 Android Studio 中更好地提供插件和任务对构建时间影响的相关信息。

你现在能做些什么?

虽然配置时间可能因变量、模块和其他因素的数


《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》
浏览器打开:qq.cn.hn/FTe 免费领取
复制代码


量而有所不同,但我们希望将与 Android Gradle 插件相关联的配置时间作为参考点,并和实际场景共享数据。



如果发现构建时间慢很多,可能是有客制化的构建逻辑(或者三方的 Gradle 插件)影响到构建时间。


使用的工具

用户头像

Android架构

关注

还未添加个人签名 2021.10.31 加入

还未添加个人简介

评论

发布
暂无评论
[译] 改善 Android Studio 的构建速度(1),美团移动端开发工程师