亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

首頁 Java java教程 Java 中的 Lombok 項(xiàng)目

Java 中的 Lombok 項(xiàng)目

Jan 08, 2025 pm 10:24 PM

Proyecto Lombok en Java

介紹

Lombok 是一個(gè)充當(dāng) Java 註解處理器的函式庫,旨在消除程式碼中的冗餘。它的主要功能是自動(dòng)產(chǎn)生重複程式碼或「樣板檔案」——這些元素雖然必要,但不會為我們的程式邏輯添加直接價(jià)值。主要用於在編譯時(shí)自動(dòng)產(chǎn)生 getter 和 setter 方法、建構(gòu)子、equals()、hashCode()、toString() 方法以及 Java 類別中的其他常見元素。

無需為這些基本功能手動(dòng)編寫數(shù)十行程式碼,Lombok 允許您使用簡單的註解來定義它們,從而產(chǎn)生更乾淨(jìng)、更易於維護(hù)且不易出錯(cuò)的程式碼。

設(shè)施

要在Java專案中使用Lombok,除了安裝之外,還需要在pom.xml檔案(如果是Maven專案)或build.gradle(如果是Gradle專案)中新增對應(yīng)的依賴我們正在使用的IDE中的相應(yīng)插件。在這篇文章中,我們將使用 Maven 和 IntelliJ IDEA 作為範(fàn)例。

<dependencies>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.36</version>
        <scope>provided</scope>
    </dependency>
</dependencies>

如有任何疑問,您可以隨時(shí)查看Lombok的官方文件:

  • Lombok 與 Maven
  • IntelliJ IDEA 中的 Lombok

@數(shù)據(jù)

當(dāng)我們建立一個(gè)類別時(shí),我們會定期執(zhí)行以下操作,無論是手動(dòng)還是使用 IDE 提供的捷徑:

  • 封裝屬性並產(chǎn)生其getter和setter方法
  • 產(chǎn)生一個(gè)空的建構(gòu)子和另一個(gè)接收所有屬性的
  • 實(shí)作 equals()、hashCode() 和 toString() 方法

嗯,Lombok 有 @Data 註釋,它允許我們在一行中完成所有這些操作,產(chǎn)生與 POJO(普通舊 Java 物件) 相關(guān)的所有內(nèi)容。這個(gè)註解是 @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

這些註解允許我們自動(dòng)產(chǎn)生具有不同參數(shù)組合的建構(gòu)函數(shù),考慮到屬性是根據(jù)它們在類別中聲明的順序使用的。

  • @NoArgsConstructor:生成一個(gè)無參構(gòu)造函數(shù)(空),如果無法生成,則會拋出異常,為了避免這種情況,只需使用如下註解 @NoArgsConstructor(force = true)。
  • @AllArgsConstructor:產(chǎn)生一個(gè)建構(gòu)函數(shù),以類別的所有屬性作為參數(shù)。
  • @RequiredArgsConstructor:為所有最終欄位產(chǎn)生構(gòu)造函數(shù)和/或用 @NonNull 註解標(biāo)記。
<dependencies>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.36</version>
        <scope>provided</scope>
    </dependency>
</dependencies>

@Getter 和 @setter

這些註解可以讓我們自動(dòng)為類別的所有屬性產(chǎn)生 getter 和 setter 方法,或只為那些標(biāo)有相應(yīng)註解的屬性產(chǎn)生 getter 和 setter 方法,即可以在類別或?qū)傩詫蛹壥褂谩?

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

此註解自動(dòng)產(chǎn)生 toString() 方法,該方法傳回類別及其屬性的字串表示形式,格式如下:ClassName(attribute1=value1, attribute2=value2, ...)。預(yù)設(shè)情況下,類別的所有非靜態(tài)屬性都包含在結(jié)果中,但可以使用 @ToString.Exclude 屬性來排除特定屬性。如果您只想顯示屬性的值而不是宣告的名稱,可以使用 @ToString(includeFieldNames = false)。

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Persona {
    private String nombre;
}

@EqualsAndHashCode

允許您從類別的所有屬性產(chǎn)生 equals() 和 hashCode() 方法,如果您想要排除或包含某個(gè)屬性,可以使用註解 @EqualsAndHashCode.Exclude 和 @EqualsAndHashCode.Include 來實(shí)作。分別。

import lombok.*;

@Getter
@Setter
public class Persona {
    private String nombre;
    private String apellido;
}

@價(jià)值

以前,在 Java 中建立不可變類別需要執(zhí)行一系列步驟,例如使類別和/或?qū)傩猿蔀樽罱K類型,並且不會產(chǎn)生 setter 方法。 Lombok 使我們可以輕鬆地使用 @Value 註解創(chuàng)建不可變類,該註解結(jié)合了 @Getter、@ToString、@EqualsAndHashCode 和 @AllArgsConstructor 註解來產(chǎn)生不可變類。所有屬性都標(biāo)記為 private Final,並且不會產(chǎn)生 setter 方法。它是 @Data 的不可變變體。

import lombok.*;

public class Persona {
    @Getter @Setter
    private String nombre;
    private String apellido;
}

在 Java 的最新版本中,與使用記錄相比,此註解失去了意義,因?yàn)樗鼈兙哂邢嗤哪康?,並且使用記錄更實(shí)用。如果您有興趣了解更多有關(guān)此主題的信息,部落格上還有更多有關(guān)記錄的帖子。

<dependencies>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.36</version>
        <scope>provided</scope>
    </dependency>
</dependencies>

@val

這個(gè)註解允許我們將一個(gè)變數(shù)宣告為final並自動(dòng)推斷它的資料類型,也就是說,不需要指定變數(shù)的資料類型,Lombok會負(fù)責(zé)推斷它。如果變數(shù)資料類型很長或很複雜,它很有用,這樣可以避免重複。

import lombok.Data;

@Data
public class Persona {
    private String nombre;
}

如果我們直接使用final var或簡單的var進(jìn)行型別推斷,這個(gè)註解可能會失去意義,因?yàn)檫@是語言的特性,這樣比較方便。如果您有興趣了解更多,可以參考以下帖子

public class Main {
    public static void main(String[] args) {
        Persona p1 = new Persona();
        p2.setNombre("Maria");

        System.out.println(p1.getNombre());
    }
}

@var

它的工作方式與@val完全相同,但它不將變數(shù)宣告為final,它只是推斷其類型。有必要考慮類型推斷的概念,因?yàn)槟荒苈暶?String 類型的內(nèi)容,並且想要為其分配 int 類型的值也不是最終的。同樣,在最新版本的 Java 中,該註解被 var 取代。

import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Persona {
    private String nombre;
}

@非空

這個(gè)註解可以用在類別的屬性和方法的參數(shù)上,它基本上表明屬性的值不能為空,如果嘗試將空值分配給標(biāo)記為@NonNull的屬性,它會拋出NullPointerException,即使用if (param == null) throw new NullPointerException("param is tagged non-null but is null"); 。無論它產(chǎn)生什麼異常,它的使用在 IDE 本身中都更加明顯,因?yàn)樗鼤阅撤N方式向我們表明該值不能為空。

import lombok.*;

@Getter
@Setter
public class Persona {
    private String nombre;
    private String apellido;
}

@清理

此註解可讓我們確保任何使用它的資源(如果它具有 close() 方法或?qū)嵶?AutoCloseable 或 Closeable 介面)都會在其所在程式碼區(qū)塊的末尾自動(dòng)關(guān)閉。它在處理需要釋放的資源時(shí)非常有用,例如檔案、資料庫連接等。

import lombok.*;

public class Persona {
    @Getter @Setter
    private String nombre;
    private String apellido;
}

如果我們使用資源嘗試,可以手動(dòng)獲得此結(jié)果。

import lombok.*;

@AllArgsConstructor
@ToString
public class Persona {
    private String nombre;
    @ToString.Exclude
    private String apellido;
}

// Output: Persona(nombre=Maria)

@builder

這個(gè)註解可以讓我們自動(dòng)產(chǎn)生一個(gè)設(shè)計(jì)模式Builder,即一個(gè)可以讓我們一步步構(gòu)建複雜對象的對象,這樣就可以配置一個(gè)對象的不同屬性,而無需調(diào)用帶有多個(gè)參數(shù)的建構(gòu)子。如果一個(gè)類別有很多屬性並且我們不希望有一個(gè)帶有許多參數(shù)的建構(gòu)函數(shù),那麼它很有用。

<dependencies>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <version>1.18.36</version>
        <scope>provided</scope>
    </dependency>
</dependencies>

@和

這個(gè)註解允許我們建立一個(gè)方法,該方法傳回帶有修改屬性的目前物件的副本,即它產(chǎn)生一個(gè)方法withAttributeName(Object object) ,該方法允許我們用該物件建立目前物件的副本屬性由我們作為參數(shù)傳遞的值修改。當(dāng)我們想要修改物件的屬性而不修改原始物件時(shí),它非常有用。

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());
    }
}

到目前為止,我們已經(jīng)看到了一些最常用的註釋,每個(gè)註釋可能接受也可能不接受額外的配置,同樣還有其他註釋被標(biāo)記為實(shí)驗(yàn)性的,無論如何,參考很重要官方文檔,以充分利用Lombok 為我們提供的所有功能以及重複程式碼產(chǎn)生的優(yōu)勢。

以上是Java 中的 Lombok 項(xiàng)目的詳細(xì)內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
Java中可呼叫和可運(yùn)行的差異 Java中可呼叫和可運(yùn)行的差異 Jul 04, 2025 am 02:50 AM

Callable和Runnable在Java中主要有三點(diǎn)區(qū)別。第一,Callable的call()方法可以返回結(jié)果,適合需要返回值的任務(wù),如Callable;而Runnable的run()方法無返回值,適用於無需返回的任務(wù),如日誌記錄。第二,Callable允許拋出checked異常,便於錯(cuò)誤傳遞;而Runnable必須在內(nèi)部處理異常。第三,Runnable可直接傳給Thread或ExecutorService,而Callable只能提交給ExecutorService,並返回Future對像以

現(xiàn)代爪哇的異步編程技術(shù) 現(xiàn)代爪哇的異步編程技術(shù) Jul 07, 2025 am 02:24 AM

Java支持異步編程的方式包括使用CompletableFuture、響應(yīng)式流(如ProjectReactor)以及Java19 中的虛擬線程。 1.CompletableFuture通過鍊式調(diào)用提升代碼可讀性和維護(hù)性,支持任務(wù)編排和異常處理;2.ProjectReactor提供Mono和Flux類型實(shí)現(xiàn)響應(yīng)式編程,具備背壓機(jī)制和豐富的操作符;3.虛擬線程減少並發(fā)成本,適用於I/O密集型任務(wù),與傳統(tǒng)平臺線程相比更輕量且易於擴(kuò)展。每種方式均有適用場景,應(yīng)根據(jù)需求選擇合適工具並避免混合模型以保持簡潔性

在Java中使用枚舉的最佳實(shí)踐 在Java中使用枚舉的最佳實(shí)踐 Jul 07, 2025 am 02:35 AM

在Java中,枚舉(enum)適合表示固定常量集合,最佳實(shí)踐包括:1.用enum表示固定狀態(tài)或選項(xiàng),提升類型安全和可讀性;2.為枚舉添加屬性和方法以增強(qiáng)靈活性,如定義字段、構(gòu)造函數(shù)、輔助方法等;3.使用EnumMap和EnumSet提高性能和類型安全性,因其基於數(shù)組實(shí)現(xiàn)更高效;4.避免濫用enum,如動(dòng)態(tài)值、頻繁變更或複雜邏輯場景應(yīng)使用其他方式替代。正確使用enum能提升代碼質(zhì)量並減少錯(cuò)誤,但需注意其適用邊界。

了解Java Nio及其優(yōu)勢 了解Java Nio及其優(yōu)勢 Jul 08, 2025 am 02:55 AM

JavaNIO是Java1.4引入的新型IOAPI,1)面向緩衝區(qū)和通道,2)包含Buffer、Channel和Selector核心組件,3)支持非阻塞模式,4)相比傳統(tǒng)IO更高效處理並發(fā)連接。其優(yōu)勢體現(xiàn)在:1)非阻塞IO減少線程開銷,2)Buffer提升數(shù)據(jù)傳輸效率,3)Selector實(shí)現(xiàn)多路復(fù)用,4)內(nèi)存映射加快文件讀寫。使用時(shí)需注意:1)Buffer的flip/clear操作易混淆,2)非阻塞下需手動(dòng)處理不完整數(shù)據(jù),3)Selector註冊需及時(shí)取消,4)NIO並非適用於所有場景。

Java Classloader在內(nèi)部如何工作 Java Classloader在內(nèi)部如何工作 Jul 06, 2025 am 02:53 AM

Java的類加載機(jī)制通過ClassLoader實(shí)現(xiàn),其核心工作流程分為加載、鏈接和初始化三個(gè)階段。加載階段由ClassLoader動(dòng)態(tài)讀取類的字節(jié)碼並創(chuàng)建Class對象;鏈接包括驗(yàn)證類的正確性、為靜態(tài)變量分配內(nèi)存及解析符號引用;初始化則執(zhí)行靜態(tài)代碼塊和靜態(tài)變量賦值。類加載採用雙親委派模型,優(yōu)先委託父類加載器查找類,依次嘗試Bootstrap、Extension和ApplicationClassLoader,確保核心類庫安全且避免重複加載。開發(fā)者可自定義ClassLoader,如URLClassL

探索Java中不同的同步機(jī)制 探索Java中不同的同步機(jī)制 Jul 04, 2025 am 02:53 AM

Javaprovidesmultiplesynchronizationtoolsforthreadsafety.1.synchronizedblocksensuremutualexclusionbylockingmethodsorspecificcodesections.2.ReentrantLockoffersadvancedcontrol,includingtryLockandfairnesspolicies.3.Conditionvariablesallowthreadstowaitfor

有效處理常見的Java例外 有效處理常見的Java例外 Jul 05, 2025 am 02:35 AM

Java異常處理的關(guān)鍵在於區(qū)分checked和unchecked異常並合理使用try-catch、finally及日誌記錄。 1.checked異常如IOException需強(qiáng)制處理,適用於可預(yù)期的外部問題;2.unchecked異常如NullPointerException通常由程序邏輯錯(cuò)誤引起,屬於運(yùn)行時(shí)錯(cuò)誤;3.捕獲異常時(shí)應(yīng)具體明確,避免籠統(tǒng)捕獲Exception;4.推薦使用try-with-resources自動(dòng)關(guān)閉資源,減少手動(dòng)清理代碼;5.異常處理中應(yīng)結(jié)合日誌框架記錄詳細(xì)信息,便於後

Hashmap在Java內(nèi)部如何工作? Hashmap在Java內(nèi)部如何工作? Jul 15, 2025 am 03:10 AM

HashMap在Java中通過哈希表實(shí)現(xiàn)鍵值對存儲,其核心在於快速定位數(shù)據(jù)位置。 1.首先使用鍵的hashCode()方法生成哈希值,並通過位運(yùn)算轉(zhuǎn)換為數(shù)組索引;2.不同對象可能產(chǎn)生相同哈希值,導(dǎo)致衝突,此時(shí)以鍊錶形式掛載節(jié)點(diǎn),JDK8後鍊錶過長(默認(rèn)長度8)則轉(zhuǎn)為紅黑樹提升效率;3.使用自定義類作鍵時(shí)必須重寫equals()和hashCode()方法;4.HashMap動(dòng)態(tài)擴(kuò)容,當(dāng)元素?cái)?shù)超過容量乘以負(fù)載因子(默認(rèn)0.75)時(shí),擴(kuò)容並重新哈希;5.HashMap非線程安全,多線程下應(yīng)使用Concu

See all articles