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 可空性宣告可能會演變,即使在次要版本之間也是如此,並且將來可能會新增更多檢查。

尚不支援泛型型別引數、可變引數和陣列元素可空性,但應在即將釋出的版本中支援。