初始见解来自:https://blog.csdn.net/qq_27093465/article/details/90056695
但是我感觉说的有点乱,虽然将里例子,但是例子不够好,我自己实验了一遍之后才弄懂。
Lombok 的 @EqualsAndHashCode(callSuper = false)翻译成中文的意思就是:
不继承父类中自动生成的EqualsAndHashCode的方法
因为父类中有父类自己的属性,所以如果选择false,则会出现同一个父类下不同实例存入不同父类属性,但是子类属性相同时,被判断这两个的实例哈希相等的逻辑错误现象。
实例代码,想省时间就直接看第三幅图和输出结果
import lombok.Data;
@Data
public class BillFather {
private long id;
public BillFather(long id) {
this.id = id;
}
}
import lombok.Data;
import lombok.EqualsAndHashCode;
@Data
@EqualsAndHashCode(callSuper = false)
public class Bill extends BillFather{
private String name;
public Bill(long id, String name) {
super(id);
this.name = name;
}
}
public class EqualsAndHashCodeTest {
public static void main(String[] args) {
Bill b1 = new Bill(1, "王五");
Bill b2 = new Bill(2, "王五");
System.out.println(b1.equals(b2));
Bill b3 = new Bill(2, "张三");
System.out.println(b1.equals(b3));
}
}
最后结果是一个true,一个false。
只写@Date的结果是和 @Date+@EqualsAndHashCode(callSuper = false)一致,所以应该是默认不继承父类中的EqualsAndHashCode的判断方法,而是只继承属性的。
为了保证从父类那继承来的属性被进行equals判断时,不会只判断父类是否相同,而不判断父类属性是否相同的问题,感觉还是在继承父类的时候加上@EqualsAndHashCode(callSuper = true)免得报bug