空安全

Kotlin 的一項關鍵特性是空安全,它在編譯時能清晰地處理 null 值。透過可空性宣告(nullability declarations)和“有值或無值”語義的表達,無需付出 Optional 等包裝類的代價,使應用程式更安全。(Kotlin 允許使用函式式結構處理可空值。請參閱這篇Kotlin 空安全綜合指南。)

儘管 Java 不允許在其型別系統中表達空安全,但 Spring Data API 使用了 org.springframework.lang 包中宣告的、對 JSR-305 工具友好的註解進行標註。預設情況下,Kotlin 中使用的 Java API 型別被識別為平臺型別,對此類型別會放寬空值檢查。Kotlin 對 JSR-305 註解的支援以及 Spring 的可空性註解為 Kotlin 開發者提供了整個 Spring Data API 的空安全支援,其優勢在於能在編譯時處理與 null 相關的問題。

請參閱Repository 方法的空值處理一文,瞭解空安全如何應用於 Spring Data Repositories。

您可以透過新增 -Xjsr305 編譯器標誌及以下選項來配置 JSR-305 檢查:-Xjsr305={strict|warn|ignore}

對於 Kotlin 1.1 及更高版本,預設行為與 -Xjsr305=warn 相同。需要 strict 值來考慮 Spring Data API 的空安全。從 Spring API 推斷出的 Kotlin 型別應在使用時瞭解 Spring API 的可空性宣告可能會發生變化,即使在次要版本之間也是如此,並且將來可能會新增更多檢查。

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