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 可空性声明可能会演变,即使在次要版本之间也是如此,并且将来可能会添加更多检查。

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