赞
踩
Lombok对于重写hashCode的算法真的是很经典,但是目前而言有一个令人难以注意到的细节。在继承关系中,父类的hashCode针对父类的所有属性进行运算,而子类的hashCode却只是针对子类才有的属性进行运算,立此贴提醒自己。
目前重写hashCode的注解有@Data,@EqualsAndHashCode
首先 @EqualsAndHashCode 标在子类上
callSuper = true,根据子类自身的字段值和从父类继承的字段值 来生成hashcode,当两个子类对象比较时,只有子类对象的本身的字段值和继承父类的字段值都相同,equals方法的返回值是true。
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;
- }
- }
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。