介紹
Lombok 是一個充當 Java 註解處理器的函式庫,旨在消除程式碼中的冗餘。它的主要功能是自動產生重複程式碼或「樣板檔案」——這些元素雖然必要,但不會為我們的程式邏輯添加直接價值。主要用於在編譯時自動產生 getter 和 setter 方法、建構子、equals()、hashCode()、toString() 方法以及 Java 類別中的其他常見元素。
無需為這些基本功能手動編寫數十行程式碼,Lombok 允許您使用簡單的註解來定義它們,從而產生更乾淨、更易於維護且不易出錯的程式碼。
設施
要在Java專案中使用Lombok,除了安裝之外,還需要在pom.xml檔案(如果是Maven專案)或build.gradle(如果是Gradle專案)中新增對應的依賴我們正在使用的IDE中的相應插件。在這篇文章中,我們將使用 Maven 和 IntelliJ IDEA 作為範例。
<dependencies> <dependency> <groupid>org.projectlombok</groupid> <artifactid>lombok</artifactid> <version>1.18.36</version> <scope>provided</scope> </dependency> </dependencies>
如有任何疑問,您可以隨時查看Lombok的官方文件:
- Lombok 與 Maven
- IntelliJ IDEA 中的 Lombok
@數據
當我們建立一個類別時,我們會定期執行以下操作,無論是手動還是使用 IDE 提供的捷徑:
- 封裝屬性並產生其getter和setter方法
- 產生一個空的建構子和另一個接收所有屬性的
- 實作 equals()、hashCode() 和 toString() 方法
嗯,Lombok 有 @Data 註釋,它允許我們在一行中完成所有這些操作,產生與 POJO(普通舊 Java 物件) 相關的所有內容。這個註解是 @Getter、@Setter、@EqualsAndHashCode、@NoArgsConstructor 和 @AllArgsConstructor 註解的組合,我們稍後會看到。
import lombok.Data; @Data public class Persona { private String nombre; }
public class Main { public static void main(String[] args) { Persona p1 = new Persona(); p2.setNombre("Maria"); System.out.println(p1.getNombre()); } }
@NoArgsConstructor、@AllArgsConstructor 和 @RequiredArgsConstructor
這些註解允許我們自動產生具有不同參數組合的建構函數,考慮到屬性是根據它們在類別中聲明的順序使用的。
- @NoArgsConstructor:生成一個無參構造函數(空),如果無法生成,則會拋出異常,為了避免這種情況,只需使用如下註解 @NoArgsConstructor(force = true)。
- @AllArgsConstructor:產生一個建構函數,以類別的所有屬性作為參數。
- @RequiredArgsConstructor:為所有最終欄位產生構造函數和/或用 @NonNull 註解標記。
<dependencies> <dependency> <groupid>org.projectlombok</groupid> <artifactid>lombok</artifactid> <version>1.18.36</version> <scope>provided</scope> </dependency> </dependencies>
@Getter 和 @setter
這些註解可以讓我們自動為類別的所有屬性產生 getter 和 setter 方法,或只為那些標有相應註解的屬性產生 getter 和 setter 方法,即可以在類別或屬性層級使用。
import lombok.Data; @Data public class Persona { private String nombre; }
public class Main { public static void main(String[] args) { Persona p1 = new Persona(); p2.setNombre("Maria"); System.out.println(p1.getNombre()); } }
@ToString
此註解自動產生 toString() 方法,該方法傳回類別及其屬性的字串表示形式,格式如下:ClassName(attribute1=value1, attribute2=value2, ...)。預設情況下,類別的所有非靜態屬性都包含在結果中,但可以使用 @ToString.Exclude 屬性來排除特定屬性。如果您只想顯示屬性的值而不是宣告的名稱,可以使用 @ToString(includeFieldNames = false)。
import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; @Data @AllArgsConstructor @NoArgsConstructor public class Persona { private String nombre; }
@EqualsAndHashCode
允許您從類別的所有屬性產生 equals() 和 hashCode() 方法,如果您想要排除或包含某個屬性,可以使用註解 @EqualsAndHashCode.Exclude 和 @EqualsAndHashCode.Include 來實作。分別。
import lombok.*; @Getter @Setter public class Persona { private String nombre; private String apellido; }
@價值
以前,在 Java 中建立不可變類別需要執行一系列步驟,例如使類別和/或屬性成為最終類型,並且不會產生 setter 方法。 Lombok 使我們可以輕鬆地使用 @Value 註解創建不可變類,該註解結合了 @Getter、@ToString、@EqualsAndHashCode 和 @AllArgsConstructor 註解來產生不可變類。所有屬性都標記為 private Final,並且不會產生 setter 方法。它是 @Data 的不可變變體。
import lombok.*; public class Persona { @Getter @Setter private String nombre; private String apellido; }
在 Java 的最新版本中,與使用記錄相比,此註解失去了意義,因為它們具有相同的目的,並且使用記錄更實用。如果您有興趣了解更多有關此主題的信息,部落格上還有更多有關記錄的帖子。
<dependencies> <dependency> <groupid>org.projectlombok</groupid> <artifactid>lombok</artifactid> <version>1.18.36</version> <scope>provided</scope> </dependency> </dependencies>
@val
這個註解允許我們將一個變數宣告為final並自動推斷它的資料類型,也就是說,不需要指定變數的資料類型,Lombok會負責推斷它。如果變數資料類型很長或很複雜,它很有用,這樣可以避免重複。
import lombok.Data; @Data public class Persona { private String nombre; }
如果我們直接使用final var或簡單的var進行型別推斷,這個註解可能會失去意義,因為這是語言的特性,這樣比較方便。如果您有興趣了解更多,可以參考以下帖子
public class Main { public static void main(String[] args) { Persona p1 = new Persona(); p2.setNombre("Maria"); System.out.println(p1.getNombre()); } }
@var
它的工作方式與@val完全相同,但它不將變數宣告為final,它只是推斷其類型。有必要考慮類型推斷的概念,因為您不能聲明 String 類型的內容,並且想要為其分配 int 類型的值也不是最終的。同樣,在最新版本的 Java 中,該註解被 var 取代。
import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; @Data @AllArgsConstructor @NoArgsConstructor public class Persona { private String nombre; }
@非空
這個註解可以用在類別的屬性和方法的參數上,它基本上表明屬性的值不能為空,如果嘗試將空值分配給標記為@NonNull的屬性,它會拋出NullPointerException,即使用if (param == null) throw new NullPointerException("param is tagged non-null but is null"); 。無論它產生什麼異常,它的使用在 IDE 本身中都更加明顯,因為它會以某種方式向我們表明該值不能為空。
import lombok.*; @Getter @Setter public class Persona { private String nombre; private String apellido; }
@清理
此註解可讓我們確保任何使用它的資源(如果它具有 close() 方法或實作 AutoCloseable 或 Closeable 介面)都會在其所在程式碼區塊的末尾自動關閉。它在處理需要釋放的資源時非常有用,例如檔案、資料庫連接等。
import lombok.*; public class Persona { @Getter @Setter private String nombre; private String apellido; }
如果我們使用資源嘗試,可以手動獲得此結果。
import lombok.*; @AllArgsConstructor @ToString public class Persona { private String nombre; @ToString.Exclude private String apellido; } // Output: Persona(nombre=Maria)
@builder
這個註解可以讓我們自動產生一個設計模式Builder,即一個可以讓我們一步步構建複雜對象的對象,這樣就可以配置一個對象的不同屬性,而無需調用帶有多個參數的建構子。如果一個類別有很多屬性並且我們不希望有一個帶有許多參數的建構函數,那麼它很有用。
<dependencies> <dependency> <groupid>org.projectlombok</groupid> <artifactid>lombok</artifactid> <version>1.18.36</version> <scope>provided</scope> </dependency> </dependencies>
@和
這個註解允許我們建立一個方法,該方法傳回帶有修改屬性的目前物件的副本,即它產生一個方法withAttributeName(Object object) ,該方法允許我們用該物件建立目前物件的副本屬性由我們作為參數傳遞的值修改。當我們想要修改物件的屬性而不修改原始物件時,它非常有用。
import lombok.Data; @Data public class Persona { private String nombre; }
public class Main { public static void main(String[] args) { Persona p1 = new Persona(); p2.setNombre("Maria"); System.out.println(p1.getNombre()); } }
到目前為止,我們已經看到了一些最常用的註釋,每個註釋可能接受也可能不接受額外的配置,同樣還有其他註釋被標記為實驗性的,無論如何,參考很重要官方文檔,以充分利用Lombok 為我們提供的所有功能以及重複程式碼產生的優勢。
以上是Java 中的 Lombok 項目的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JVM通過字節碼解釋、平台無關的API和動態類加載實現Java的WORA特性:1.字節碼被解釋為機器碼,確保跨平台運行;2.標準API抽像操作系統差異;3.類在運行時動態加載,保證一致性。

Java的最新版本通過JVM優化、標準庫改進和第三方庫支持有效解決平台特定問題。 1)JVM優化,如Java11的ZGC提升了垃圾回收性能。 2)標準庫改進,如Java9的模塊系統減少平台相關問題。 3)第三方庫提供平台優化版本,如OpenCV。

JVM的字節碼驗證過程包括四個關鍵步驟:1)檢查類文件格式是否符合規範,2)驗證字節碼指令的有效性和正確性,3)進行數據流分析確保類型安全,4)平衡驗證的徹底性與性能。通過這些步驟,JVM確保只有安全、正確的字節碼被執行,從而保護程序的完整性和安全性。

Java'splatFormIndepentEncealLowsApplicationStorunonAnyOperatingsystemwithajvm.1)singleCodeBase:writeandeandcompileonceforallplatforms.2)easileupdates:updatebybytecodeforsimultanane deployment.3)testOnOneOnePlatForforurouniverSalpeforuluniverSalpehavior formafforulululyiversalivernave.444.44.444

Java的平台獨立性通過JVM、JIT編譯、標準化、泛型、lambda表達式和ProjectPanama等技術不斷增強。自1990年代以來,Java從基本的JVM演進到高性能的現代JVM,確保了代碼在不同平台的一致性和高效性。

Java如何緩解平台特定的問題? Java通過JVM和標準庫來實現平台無關性。 1)使用字節碼和JVM抽像操作系統差異;2)標準庫提供跨平台API,如Paths類處理文件路徑,Charset類處理字符編碼;3)實際項目中使用配置文件和多平台測試來優化和調試。

java'splatformentenceenhancesenhancesmicroservicesharchitecture byferingDeploymentFlexible,一致性,可伸縮性和便攜性。 1)DeploymentFlexibilityAllowsibilityAllowsOllowsOllowSorlowsOllowsOllowsOllowSeStorunonAnyPlatformwithajvM.2)penterencyCrossServAccAcrossServAcrossServiCessImplifififiesDeevelopmentandeDe

GraalVM通過三種方式增強了Java的平台獨立性:1.跨語言互操作,允許Java與其他語言無縫互操作;2.獨立的運行時環境,通過GraalVMNativeImage將Java程序編譯成本地可執行文件;3.性能優化,Graal編譯器生成高效的機器碼,提升Java程序的性能和一致性。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。