脚本、预编译脚本或二进制插件之间的选择取决于您的具体要求和偏好。

脚本插件简单易写。它们用 Kotlin DSL 或 Groovy DSL 编写。它们适用于小型、一次性任务或快速实验。然而,随着构建脚本的规模和复杂性增加,它们可能变得难以维护。

预编译脚本插件是将 Kotlin 或 Groovy DSL 脚本编译成 Java 类文件并打包成库。与脚本插件相比,它们提供更好的性能和可维护性,并且可以在不同项目之间重用。您也可以用 Groovy DSL 编写它们,但不推荐。

二进制插件是用 Java、Groovy 或 Kotlin 编写的成熟插件,编译成 JAR 文件并发布到仓库。它们提供最佳的性能、可维护性和可重用性。它们适用于需要在项目、构建和团队之间共享的复杂构建逻辑。您也可以用 Scala 或 Groovy 编写它们,但不推荐。

以下是实现 Gradle 插件的所有选项的细分

# 使用 类型 插件是 推荐?

1

Kotlin DSL

脚本插件

.gradle.kts 文件中作为抽象类,实现 Plugin<Project> 接口的 apply(Project project) 方法。

[1]

2

Groovy DSL

脚本插件

.gradle 文件中作为抽象类,实现 Plugin<Project> 接口的 apply(Project project) 方法。

[1]

3

Kotlin DSL

预编译脚本插件

一个 .gradle.kts 文件。

4

Groovy DSL

预编译脚本插件

一个 .gradle 文件。

可以[2]

5

Java

二进制插件

在 Java 中实现 Plugin<Project> 接口的 apply(Project project) 方法的抽象类。

6

Kotlin / Kotlin DSL

二进制插件

在 Kotlin 和/或 Kotlin DSL 中实现 Plugin<Project> 接口的 apply(Project project) 方法的抽象类。

7

Groovy / Groovy DSL

二进制插件

在 Groovy 和/或 Groovy DSL 中实现 Plugin<Project> 接口的 apply(Project project) 方法的抽象类。

可以[2]

8

Scala

二进制插件

在 Scala 中实现 Plugin<Project> 接口的 apply(Project project) 方法的抽象类。

[2]

如果您怀疑插件代码存在问题,请尝试创建构建扫描以识别瓶颈。Gradle 分析器可以帮助自动生成构建扫描并收集更低级别的信息。


1. 脚本插件难以维护。请勿使用 apply from: 脚本插件,不推荐使用。
2. 建议使用像 JavaKotlin 这样的静态类型语言来实现插件,以减少二进制不兼容的可能性。如果使用 Groovy,请考虑使用静态编译的 Groovy