Null 安全性

Kotlin 的主要特性之一是 null 安全性,它可以在编译时干净地处理 null 值。这通过可空性声明和“值或无值”语义的表达,使应用程序更安全,而无需付出包装器(如 Optional)的代价。(Kotlin 允许将函数式结构与可空值一起使用。请参阅这篇 Kotlin null 安全性综合指南。)

虽然 Java 不允许你在其类型系统中表达 null 安全性,但 Spring Data API 使用在 org.springframework.lang 包中声明的、对 JSR-305 工具友好的注解进行标注。默认情况下,在 Kotlin 中使用的 Java API 中的类型被识别为 平台类型,对于这些类型,null 检查会放松。 Kotlin 对 JSR-305 注解的支持和 Spring 可空性注解为 Kotlin 开发人员提供了整个 Spring Data API 的 null 安全性,优点是在编译时处理与 null 相关的问题。

请参阅 仓库方法的 Null 处理,了解 null 安全性如何应用于 Spring Data 仓库。

你可以通过添加 -Xjsr305 编译器标志以及以下选项来配置 JSR-305 检查:-Xjsr305={strict|warn|ignore}

对于 Kotlin 1.1+ 版本,默认行为与 -Xjsr305=warn 相同。 需要 strict 值才能考虑 Spring Data API 的 null 安全性。 从 Spring API 推断出的 Kotlin 类型应该在知道 Spring API 可空性声明可能会演变(即使在次要版本之间),并且将来可能会添加更多检查的情况下使用。

泛型类型参数、varargs 和数组元素的可空性尚不支持,但应该会在即将发布的版本中提供。