Lombok 中 @EqualsAndHashCode注解的使用

  • Post author:
  • Post category:其他


@EqualsAndHashCode注解的作用就是自动实现model类的equals方法和hashcode方法。

我们在实际工作中经常会使用lombok来简化我们的开发,例如我们可以在定义的model类上添加@Data注解,从而免去手写get、set、toString、equals、hashcode等方法。

先来看问题:

1、定义一个基础类Car

/**
 * 汽车
 */
@Data
public class Car {

    /**
     * 颜色
     */
    private String color;

    /**
     * 续航
     */
    private Integer endurance;

}

2、定义一个扩展类BYD继承Car

/**
 * 比亚迪汽车
 */
@Data
public class BYD extends Car {

    /**
     * 价格
     */
    private Integer price;

}

3、分别new两个对象并比较

public class EqualsAndHashCodeTest {

    public static void main(String[] args) {
        BYD bydBlue = new BYD();
        bydBlue.setPrice(150000);
        bydBlue.setColor("蓝色");
        bydBlue.setEndurance(1200);

        BYD bydWhite = new BYD();
        bydWhite.setPrice(150000);
        bydWhite.setColor("白色");
        bydWhite.setEndurance(1200);

        System.out.println("两个对象比较结果:" + bydBlue.equals(bydWhite));
    }

}

4、查看比较结果

我们会发现明明new的是两个不同的对象,但是使用equals比较出来的结果却是true。


原因是它没有调用父类的中属性,而是直接使用的子类中的属性来生成hashcode,所以当子类中的属性参数一样时,使用equals比较结果的为true。


解决办法:


添加@EqualsAndHashCode(callSuper = true)注解

或者

不使用@Data注解。


@EqualsAndHashCode(callSuper = true),就是用自己的属性和从父类继承的属性来生成hashcode;


@EqualsAndHashCode(callSuper = false),就是只用自己的属性来生成hashcode;


@Data相当于@Getter @Setter @RequiredArgsConstructor @ToString @EqualsAndHashCode这5个注解的合集, 和@EqualsAndHashCode默认是false。

例:

/**
 * 比亚迪汽车
 */
@Data
@EqualsAndHashCode(callSuper = true)
public class BYD extends Car {

    /**
     * 价格
     */
    private Integer price;

}



———————————或——————————

/**
 * 比亚迪汽车
 */
@Getter
@Setter
public class BYD extends Car {

    /**
     * 价格
     */
    private Integer price;

}



版权声明:本文为Rookie_cc原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。