Lombok 中 @EqualsAndHashCode注解的使用
@EqualsAndHashCode注解的作用
- @EqualsAndHashCode注解的作用就是自动实现model类的equals方法和hashcode方法。
- 我们在实际工作中经常会使用lombok来简化我们的开发,例如我们可以在定义的model类上添加@Data注解,从而免去手写get、set、toString、equals、hashcode等方法。
定义一个基础类Car
-
/** * 汽车 */ @Data public class Car { /** * 颜色 */ private String color; /** * 续航 */ private Integer endurance; }
定义一个扩展类BYD继承Car
-
/** * 比亚迪汽车 */ @Data public class BYD extends Car { /** * 价格 */ private Integer price; }
分别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)); }
查看比较结果
-
我们会发现明明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; }