Kotlin 语言参考文档 中文版 Help

Kotlin Gradle plugin 中的二进制兼容性验证

二进制兼容性验证可以帮助库的开发者确保使用者在升级到新的版本时不会破坏他们的代码. 这不仅有助于提供顺畅的升级体验, 而且有助于与使用者建立长期的信任, 并鼓励他们继续采用这个库.

从 2.2.0 版开始, Kotlin Gradle plugin 支持二进制兼容性验证. 启用这个功能之后, 它会根据当前代码生成应用程序二进制接口(Application Binary Interface, ABI) dump, 并与之前的 dump 比较, 以便突出显示差异. 你可以审核这些变更, 找出任何潜在的二进制不兼容的修改, 并采取进一步措施解决这些问题.

如何启用

要启用二进制兼容性验证, 请在你的 build.gradle.kts 文件中添加以下 kotlin{} 代码段:

kotlin { @OptIn(org.jetbrains.kotlin.gradle.dsl.abi.ExperimentalAbiValidation::class) abiValidation { // 使用 set() 函数, 确保与旧的 Gradle 版本兼容 enabled.set(true) } }
kotlin { abiValidation { enabled = true } }

如果你的项目存在多个模块, 想要检查二进制兼容性, 请对每个模块单独配置.

检查二进制兼容性问题

在修改你的代码之后, 要检查潜在的二进制不兼容问题, 请在 IntelliJ IDEA 中运行 checkLegacyAbi Gradle 任务, 或在你的项目目录中使用以下命令:

./gradlew checkLegacyAbi

这个 Gradle 任务会比较 ABI dump, 并将检测到的差异作为错误打印输出. 请仔细查看输出, 检查是否需要修改代码来保持二进制兼容性.

更新参考 ABI dump

Gradle 检查你的最新变更时会使用参考 ABI dump, 如果要更新它, 请在 IntelliJ IDEA 中运行 updateLegacyAbi 任务, 或在你的项目目录中使用以下命令:

./gradlew updateLegacyAbi

只有在你确信你的变更保持了与之前版本的二进制兼容性时, 才更新参考 dump.

配置过滤器

你可以定义过滤器, 来控制 ABI dump 中包含哪些类, 属性, 和函数. 请使用 filters {} 代码段, 在其中使用 excluded {}included {} 代码段来添加排除规则和包含规则.

只有在一个声明不匹配任何排除规则时, Gradle 才会在 ABI dump 中包含这个声明. 在定义包含规则时, 声明必须匹配一个包含规则, 或者存在至少一个成员匹配包含规则.

规则可以基于以下形式:

  • 一个类, 属性, 或函数的完全限定名称 (byNames).

  • 具有 BINARY 或 RUNTIME retention 的注解名称 (annotatedWith).

例如:

kotlin { @OptIn(org.jetbrains.kotlin.gradle.dsl.abi.ExperimentalAbiValidation::class) abiValidation { filters { excluded { byNames.add("**.InternalUtils") annotatedWith.add("com.example.annotations.InternalApi") } included { byNames.add("com.example.api.**") annotatedWith.add("com.example.annotations.PublicApi") } } } }
kotlin { abiValidation { filters { excluded { byNames.add("**.InternalUtils") annotatedWith.add("com.example.annotations.InternalApi") } included { byNames.add("com.example.api.**") annotatedWith.add("com.example.annotations.PublicApi") } } } }

在这个示例中:

  • 排除了:

    • InternalUtils 类.

    • 标注了 @InternalApi 注解的声明.

  • 包含了:

    • com.example.api 包中的所有内容.

    • 标注了 @PublicApi 注解的声明.

关于过滤, 详情请参见 Kotlin Gradle plugin API 参考文档.

防止对不支持的目标的推断变更

在跨平台项目中, 如果你的主机系统不能编译所有的目标平台, Kotlin Gradle plugin 会尝试根据可用的目标平台推断 ABI 变更. 这可以有助于避免在你之后切换到支持更多目标平台的主机时发生误报的失败.

要禁用这个行为, 请向你的 build.gradle.kts 文件添加以下设置:

kotlin { @OptIn(org.jetbrains.kotlin.gradle.dsl.abi.ExperimentalAbiValidation::class) abiValidation { klib { keepUnsupportedTargets.set(false) } } }
kotlin { abiValidation { klib { keepUnsupportedTargets = false } } }

如果一个目标平台不被支持, 而且推断功能已被禁用, checkLegacyAbi task 会失败, 因为它不能生成一个完整的 ABI dump. 如果你倾向于让任务失败, 而不是冒遗漏一个二进制不兼容的修改的风险, 那么这个行为可能是有用的.

2025/08/04