如何為您的Java 程式碼選擇正確的@NotNull 註解
為了增強程式碼可讀性並防止NullPointerException,許多開發人員尋求利用工具例如IDE靜態分析和FindBugs。然而,等效的 @NotNull/@NonNull 註釋的激增可能令人望而生畏。本文深入研究了可用選項,以幫助您選擇最合適的選項。
等效註釋
以下列表提供了來自各種包的等效 @NotNull 註釋:
標準選擇
標準選擇lombok.NonNull 比較javax.validation.constraints 和javax.annotation(需要額外的依賴項),顯示javax.annotation 的輕微偏好,因為它的 實現 javax.validation.constr aints(有執行時期註解的實作) 差異:執行時間註解(javax.annotation、javax.validation.constraints、 org.checkerframework.checker.nullness.qual) 提供額外的執行時間檢查,但影響小於預期。 其他在所有 JLS 上下文上啟用註解(lombok、 org.jetbrains.annotations)。 根據討論的標準,@NotNull 註解的實用選擇是 javax.annotation.Nonnull。它的簡潔性、運行時註解以及與 JLS 上下文的兼容性為可讀性、靜態分析和運行時檢查提供了平衡的解決方案。
org.checkerframework.checker.nullness.qual
javax.annotation(較長的實作)
一些遵循 JLS 9.6.4.1樣式上下文(android.support.annotation、edu.umd.cs.findbugs.annotations、org.jetbrains.annotation、lombok、javax.validation.constraints)。
以上是我應該為我的 Java 程式碼選擇哪種'@NotNull”註解?的詳細內容。更多資訊請關注PHP中文網其他相關文章!