Lombok的hashCode方法

Lombok对于重写hashCode的算法真的是很经典,但是目前而言有一个令人难以注意到的细节。在继承关系中,父类的hashCode针对父类的所有属性进行运算,而子类的hashCode却只是针对子类才有的属性进行运算,立此贴提醒自己。

目前重写hashCode的注解有@Data,@EqualsAndHashCode

首先 @EqualsAndHashCode 标在子类上

  1. callSuper = true,根据子类自身的字段值和从父类继承的字段值 来生成hashcode,当两个子类对象比较时,只有子类对象的本身的字段值和继承父类的字段值都相同,equals方法的返回值是true。

  2. callSuper = false,根据子类自身的字段值 来生成hashcode, 当两个子类对象比较时,只有子类对象的本身的字段值相同,父类字段值可以不同,equals方法的返回值是true。

public class HashCodeTest {
    public static void main(String[] args) {
        Cat cat1 = new Cat("黑色", "旺财", 2);
        Cat cat2 = new Cat("白色", "旺财", 2);
 
        System.out.println(cat1.equals(cat2));
    }
}
 
@Data
@NoArgsConstructor
@AllArgsConstructor
class Animal {
    private String color;
}
 
@Data
@EqualsAndHashCode(callSuper = true) //父类字段
class Cat extends Animal {
    private String name;
    private Integer age;
 
    public Cat(String color, String name, Integer age) {
        super(color);
        this.name = name;
        this.age = age;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值