欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Lombok中@Data如何使用

這篇文章給大家介紹Lombok中@Data如何使用,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對(duì)大家能有所幫助。

從事四川聯(lián)通機(jī)房服務(wù)器托管,服務(wù)器租用,云主機(jī),網(wǎng)站空間,域名注冊(cè),CDN,網(wǎng)絡(luò)代維等服務(wù)。

。

Lombok

先來(lái)簡(jiǎn)單介紹一下 Lombok ,其官方介紹如下:

Project Lombok makes java a spicier language by adding 'handlers' that know how to build and compile simple, boilerplate-free, not-quite-java code.

大致意思是 Lombok 通過(guò)增加一些"處理程序",可以讓 Java 代碼變得簡(jiǎn)潔、快速。

Lombok 提供了一系列的注解幫助我們簡(jiǎn)化代碼,比如:

注解名稱(chēng)功能@Setter自動(dòng)添加類(lèi)中所有屬性相關(guān)的 set 方法@Getter自動(dòng)添加類(lèi)中所有屬性相關(guān)的 get 方法@Builder使得該類(lèi)可以通過(guò) builder (建造者模式)構(gòu)建對(duì)象@RequiredArgsConstructor生成一個(gè)該類(lèi)的構(gòu)造方法,禁止無(wú)參構(gòu)造@ToString重寫(xiě)該類(lèi)的toString()方法@EqualsAndHashCode重寫(xiě)該類(lèi)的equals()hashCode()方法@Data等價(jià)于上面的@Setter、@Getter、@RequiredArgsConstructor、@ToString、@EqualsAndHashCode

看起來(lái)似乎這些注解都很正常,并且對(duì)我們的代碼也有一定的優(yōu)化,那為什么說(shuō)@Data注解存在坑呢?

@Data注解

內(nèi)部實(shí)現(xiàn)

由上面的表格我們可以知道,@Data是包含了@EqualsAndHashCode的功能,那么它究竟是如何重寫(xiě)equals()hashCode()方法的呢?

我們定義一個(gè)類(lèi)TestA

@Data
public class TestA {

    String oldName;
}

我們將其編譯后的 class 文件進(jìn)行反編譯:

public class TestA {

    String oldName;

    public TestA() {
    }

    public String getOldName() {
        return this.oldName;
    }

    public void setOldName(String oldName) {
        this.oldName = oldName;
    }

    public boolean equals(Object o) {
        // 判斷是否是同一個(gè)對(duì)象
        if (o == this) {
            return true;
        }
        // 判斷是否是同一個(gè)類(lèi)
        else if (!(o instanceof TestA)) {
            return false;
        } else {
            TestA other = (TestA) o;
            if (!other.canEqual(this)) {
                return false;
            } else {
                // 比較類(lèi)中的屬性(注意這里,只比較了當(dāng)前類(lèi)中的屬性)
                Object this$oldName = this.getOldName();
                Object other$oldName = other.getOldName();
                if (this$oldName == null) {
                    if (other$oldName != null) {
                        return false;
                    }
                } else if (!this$oldName.equals(other$oldName)) {
                    return false;
                }

                return true;
            }
        }
    }

    protected boolean canEqual(Object other) {
        return other instanceof TestA;
    }

    public int hashCode() {
        int PRIME = true;
        int result = 1;
        Object $oldName = this.getOldName();
        int result = result * 59 + ($oldName == null ? 43 : $oldName.hashCode());
        return result;
    }

    public String toString() {
        return "TestA(oldName=" + this.getOldName() + ")";
    }
}

針對(duì)其equals()方法,當(dāng)它進(jìn)行屬性比較時(shí),其實(shí)只比較了當(dāng)前類(lèi)中的屬性。如果你不信的話,我們?cè)賮?lái)創(chuàng)建一個(gè)類(lèi)TestB,它是TestA的子類(lèi):

@Data
public class TestB extends TestA {

    private String name;

    private int age;
}

我們將其編譯后的 class 文件進(jìn)行反編譯:

public class TestB extends TestA {

    private String name;

    private int age;

    public TestB() {
    }

    public String getName() {
        return this.name;
    }

    public int getAge() {
        return this.age;
    }

    public void setName(String name) {
        this.name = name;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public boolean equals(Object o) {
        if (o == this) {
            return true;
        } else if (!(o instanceof TestB)) {
            return false;
        } else {
            TestB other = (TestB)o;
            if (!other.canEqual(this)) {
                return false;
            } else {
                // 注意這里,真的是只比較了當(dāng)前類(lèi)中的屬性,并沒(méi)有比較父類(lèi)中的屬性
                Object this$name = this.getName();
                Object other$name = other.getName();
                if (this$name == null) {
                    if (other$name == null) {
                        return this.getAge() == other.getAge();
                    }
                } else if (this$name.equals(other$name)) {
                    return this.getAge() == other.getAge();
                }

                return false;
            }
        }
    }

    protected boolean canEqual(Object other) {
        return other instanceof TestB;
    }

    public int hashCode() {
        int PRIME = true;
        int result = 1;
        Object $name = this.getName();
        int result = result * 59 + ($name == null ? 43 : $name.hashCode());
        result = result * 59 + this.getAge();
        return result;
    }

    public String toString() {
        return "TestB(name=" + this.getName() + ", age=" + this.getAge() + ")";
    }
}

按照代碼的理解,如果兩個(gè)子類(lèi)對(duì)象,其子類(lèi)中的屬性相同、父類(lèi)中的屬性不同時(shí),利用equals()方法時(shí),依舊會(huì)認(rèn)為這兩個(gè)對(duì)象相同,測(cè)試一下:

public static void main(String[] args) {
        TestB t1 = new TestB();
        TestB t2 = new TestB();

        t1.setOldName("123");
        t2.setOldName("12345");

        String name = "1";
        t1.name = name;
        t2.name = name;

        int age = 1;
        t1.age = age;
        t2.age = age;

        System.out.println(t1.equals(t2));
        System.out.println(t2.equals(t1));
        System.out.println(t1.hashCode());
        System.out.println(t2.hashCode());
        System.out.println(t1 == t2);
        System.out.println(Objects.equals(t1, t2));
    }

結(jié)果為:

true
true
6373
6373
false
true

問(wèn)題總結(jié)

對(duì)于父類(lèi)是Object且使用了 @EqualsAndHashCode(callSuper = true)注解的類(lèi),這個(gè)類(lèi)由 Lombok 生成的 equals()方法只有在兩個(gè)對(duì)象是同一個(gè)對(duì)象時(shí),才會(huì)返回 true ,否則總為 false ,無(wú)論它們的屬性是否相同。
這個(gè)行為在大部分時(shí)間是不符合預(yù)期的, equals()失去了其意義。即使我們期望 equals()是這樣工作的,那么其余的屬性比較代碼便是累贅,會(huì)大幅度降低代碼的分支覆蓋率。

解決方法

  1. 用了@Data就不要有繼承關(guān)系,類(lèi)似 Kotlin 的做法。

  2. 自己重寫(xiě)equals(), Lombok 不會(huì)對(duì)顯式重寫(xiě)的方法進(jìn)行生成。

  3. 顯式使用@EqualsAndHashCode(callSuper = true), Lombok 會(huì)以顯式指定的為準(zhǔn)。

關(guān)于Lombok中@Data如何使用就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

分享文章:Lombok中@Data如何使用
文章轉(zhuǎn)載:http://www.aaarwkj.com/article40/pegheo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站排名、ChatGPT、網(wǎng)頁(yè)設(shè)計(jì)公司、營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、企業(yè)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)
亚洲国产日韩欧美在线| 国产精品一区二区av不卡| 国产成年人在线免费观看| 亚洲午夜一区二区不卡| 国产a级一区二区三区| 深夜av免费在线观看| 欧美熟妇精品一级视频| 99国产精品欧美一区二区| 大片天天看菲色亚洲黄色| 欧美视频亚洲视频自拍视频| 日韩欧美国产综合第一页| av影片在线观看不卡| 求个手机免费在线观看av网址| 未满十八勿进黄网观看| 日本一本高清免费不卡| 久久国产精品成人av| 国产又大又长又粗又硬又猛| 精品亚洲一区二区三区| 精品国产一区二区av麻豆| 日韩电影一区二区在线观看中文字幕 | 玩弄丰满熟妇留守妇女| 成人在线观看一区二区三区| 小黄片免费在线播放观看| 久久青草精品欧美日韩精品| 日本人妻中文字幕在线一区| 亚洲欧美日韩国产桃色| 97门久欧美日韩久久| 白浆视频在线免费观看| 国产夫妻性生活视频播放| 日本精品一区二区三区免费| 亚洲天堂av现在观看| 高清在线一区二区在线| 女同同性av观看免费| 亚洲一区麻豆文化传媒| 中文字幕人妻丝袜二区| 中文字幕一区二区精品人妻| 国产欧美高清在线观看视频| 日本黄色中文字幕网站| 国内精品久久久国产盗摄| 日本一区二区三区加勒比| 中文字幕精品久久久人妻|