Lombok簡(jiǎn)單使用

Lombok簡(jiǎn)介

Lombok是一個(gè)可以通過(guò)簡(jiǎn)單的注解形式來(lái)幫助我們簡(jiǎn)化消除一些必須有但顯得很臃腫的Java代碼的工具矫夯,通過(guò)使用對(duì)應(yīng)的注解才菠,可以在編譯源碼的時(shí)候生成對(duì)應(yīng)的方法董朝。

簡(jiǎn)單來(lái)說(shuō),我們平時(shí)開(kāi)發(fā)過(guò)程中總是要花很多時(shí)間為Java Bean 去創(chuàng)建gettersetter方法斋否,當(dāng)類里面的屬性很多時(shí)則創(chuàng)建的gettersetter就很多谷羞,代碼就很長(zhǎng)。而lombok就可以為我們省去創(chuàng)建gettersetter方法的麻煩,代碼也會(huì)更加簡(jiǎn)潔溶诞。

Lombok官方地址: https://projectlombok.org/

使用方法

一鸯檬、安裝插件

操作步驟:File -> Settings... -> Plugins -> Browse repositories... -> 輸入Lombok搜索并安裝决侈,安裝完成后重啟IntelliJ IDEA。

Idea設(shè)置頁(yè)面
查找Lombok

二喧务、引用jar包

如果是使用Maven構(gòu)建項(xiàng)目赖歌,則添加以下依賴:

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

否則直接下載jar包并引入到項(xiàng)目中,下載地址為:下載Lombok

三功茴、lombok使用

lombok的使用主要是通過(guò)注解方式庐冯,官網(wǎng)文檔lombok注解 有很詳細(xì)的說(shuō)明。

@@NonNull

@NonNull為方法或構(gòu)造函數(shù)的參數(shù)生成null檢查語(yǔ)句坎穿,相當(dāng)于if (param == null) throw new NullPointerException("param");展父;生成的null檢查語(yǔ)句會(huì)插入到方法的最前端返劲,如果是構(gòu)造函數(shù),則在this()super()調(diào)用之后插入null檢查栖茉。

使用lombok,我們可以這樣寫:

import lombok.NonNull;

public class User extends BaseEntity {
  private String name;
  private String password;
  
  public User(@NonNull Person person) {
    super("Hello");
    this.name = person.getName();
    this.password = person.getPassword();
  }
}

而不使用lombok則是這樣寫:

import lombok.NonNull;

public class User extends BaseEntity {
  private String name;
  private String password;
  
  public User(@NonNull Person person) {
    super("Hello");
    if (person == null) {
      throw new NullPointerException("person");
    }
    this.name = person.getName();
    this.password = person.getPassword();
  }
}

@Getter/@Setter

使用@Getter/@Setter給字段注解吕漂,lombok會(huì)自動(dòng)生成默認(rèn)的getter/setter方法亲配,在Intellij IDEA的Structure欄中可查看這個(gè)類的概要,就可以看到gettersetter方法已被添加到User類中:

getter和setter方法

在未指定字段修飾符情況下惶凝,lombok生成的getter/setter方法是public的吼虎,若要修改其修飾符可設(shè)置AccessLevel的值,如:

import lombok.AccessLevel;
import lombok.Getter;
import lombok.Setter;

public class User {

    private @Getter(AccessLevel.PRIVATE) @Setter String name;

    private @Getter @Setter String password;

}

此時(shí)能看到User類中的getName方法的圖標(biāo)變成了一個(gè)鎖苍鲜,說(shuō)明getName方法已經(jīng)是private的思灰,將不會(huì)被公開(kāi):

getter方法設(shè)置AccessLevel

@ToString

使用@ToString會(huì)生成toString()方法,它會(huì)按順序依次打印類名坡贺、字段官辈;若想忽略輸出字段,則可以用exclude設(shè)置參數(shù)遍坟;如果有繼承父類拳亿,可以設(shè)置callSupertrue讓其調(diào)用父類toString()方法:

@ToString(exclude = "password", callSuper = true)
public class User extends BaseEntity {

    private @Getter @Setter String name;

    private @Getter @Setter String password;

}

@EqualsAndHashCode

使用@EqualsAndHashCode會(huì)生成hashCode()equals()方法,默認(rèn)會(huì)使用所有非靜態(tài)愿伴、非transient字段肺魁;
如果想排除某些字段可設(shè)置exclude參數(shù);
如果有繼承父類隔节,可以設(shè)置callSupertrue讓其調(diào)用父類生成的equals()hashCode方法鹅经,但是當(dāng)沒(méi)有繼承父類并設(shè)置callSupertrue時(shí)會(huì)在編譯時(shí)報(bào)錯(cuò):

import lombok.*;

@EqualsAndHashCode(exclude = "password")
public class User {

    private @Getter @Setter String name;

    private @Getter @Setter String password;

    @EqualsAndHashCode(callSuper = true)
    public static class Department extends BaseEntity {
        private @Getter @Setter String departmentName;
    }
}

在Intellij IDEA的Structure欄中可查看到有equals()hashCode()方法:

@EqualsAndHashCode

@NoArgsConstructor, @RequiredArgsConstructor, @AllArgsConstructor

@NoArgsConstructor

生成一個(gè)無(wú)參數(shù)構(gòu)造函數(shù):

@NoArgsConstructor
@RequiredArgsConstructor

生成構(gòu)造函數(shù);如果帶有參數(shù)怎诫,則該參數(shù)必須是以final修飾并未初始化的字段或@NonNull注解的并未初始化的字段瘾晃,參數(shù)的順序和字段在類中的聲明順序一致。

@NonNull注解并未初始化的:

@RequiredArgsConstructor

final修飾并未初始化的:

@RequiredArgsConstructor

正確和錯(cuò)誤示例:

@RequiredArgsConstructor
@AllArgsConstructor

生成全參數(shù)構(gòu)造函數(shù)幻妓,將類中的每個(gè)字段生成帶有1個(gè)參數(shù)的構(gòu)造函數(shù)蹦误,例如有3個(gè)字段,則構(gòu)造函數(shù)的參數(shù)為3個(gè):

@AllArgsConstructor

@Data

@Data包含了@ToString, @EqualsAndHashCode, @Getter, @Setter, @RequiredArgsConstructor的功能:

@Data

@Builder

@Builder為類肉津、構(gòu)造器强胰、方法上生成復(fù)雜的構(gòu)建器API;構(gòu)造實(shí)例時(shí)妹沙,其屬性不再需要單獨(dú)set偶洋,可以通過(guò)以下方式進(jìn)行實(shí)例化:
Person.builder().name("Adam Savage").city("San Francisco").job("Mythbusters").job("Unchained Reaction").build();

其他注解

val@Cleanup距糖、@SneakyThrows玄窝、@Synchronized牵寺、@Getter(lazy=true)@Log恩脂、experimental等就不再做介紹缸剪,用法和說(shuō)明可查看官網(wǎng)文檔https://projectlombok.org/features/all

總結(jié)

使用lombok能夠?yàn)槲覀兪∪ナ謩?dòng)創(chuàng)建gettersetter方法的麻煩东亦,lombok 有助于代碼的整潔杏节、效率的提高以及冗余的減少,但也同時(shí)降低了源代碼文件的可讀性和完整性典阵。

不可過(guò)度依賴lombok奋渔。

參考

以簡(jiǎn)單的方式消除 Java 的冗長(zhǎng)

Lombok features

lombok

原文地址:https://www.lwhweb.com/2017/11/08/lombok-use/

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市壮啊,隨后出現(xiàn)的幾起案子嫉鲸,更是在濱河造成了極大的恐慌,老刑警劉巖歹啼,帶你破解...
    沈念sama閱讀 222,378評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件玄渗,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡狸眼,警方通過(guò)查閱死者的電腦和手機(jī)藤树,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,970評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)拓萌,“玉大人岁钓,你說(shuō)我怎么就攤上這事∥⑼酰” “怎么了屡限?”我有些...
    開(kāi)封第一講書人閱讀 168,983評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)炕倘。 經(jīng)常有香客問(wèn)我钧大,道長(zhǎng),這世上最難降的妖魔是什么罩旋? 我笑而不...
    開(kāi)封第一講書人閱讀 59,938評(píng)論 1 299
  • 正文 為了忘掉前任啊央,我火速辦了婚禮,結(jié)果婚禮上瘸恼,老公的妹妹穿的比我還像新娘劣挫。我一直安慰自己册养,他們只是感情好东帅,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,955評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著球拦,像睡著了一般靠闭。 火紅的嫁衣襯著肌膚如雪帐我。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 52,549評(píng)論 1 312
  • 那天愧膀,我揣著相機(jī)與錄音拦键,去河邊找鬼。 笑死檩淋,一個(gè)胖子當(dāng)著我的面吹牛芬为,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蟀悦,決...
    沈念sama閱讀 41,063評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼媚朦,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了日戈?” 一聲冷哼從身側(cè)響起询张,我...
    開(kāi)封第一講書人閱讀 39,991評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎浙炼,沒(méi)想到半個(gè)月后份氧,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,522評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡弯屈,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,604評(píng)論 3 342
  • 正文 我和宋清朗相戀三年蜗帜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片资厉。...
    茶點(diǎn)故事閱讀 40,742評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡钮糖,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出酌住,到底是詐尸還是另有隱情店归,我是刑警寧澤,帶...
    沈念sama閱讀 36,413評(píng)論 5 351
  • 正文 年R本政府宣布酪我,位于F島的核電站消痛,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏都哭。R本人自食惡果不足惜秩伞,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,094評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望欺矫。 院中可真熱鬧纱新,春花似錦、人聲如沸穆趴。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,572評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)未妹。三九已至簿废,卻和暖如春空入,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背族檬。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,671評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工歪赢, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人单料。 一個(gè)月前我還...
    沈念sama閱讀 49,159評(píng)論 3 378
  • 正文 我出身青樓埋凯,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親扫尖。 傳聞我的和親對(duì)象是個(gè)殘疾皇子递鹉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,747評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容