当对象需要根据值去比较它们是否相等时,需要我们重写equals,而它的hashCode也同时需要被重要,一般来说就是对类里所有成员变更求hashCode。
一个类型Demo,有两个实例demo1和demo2,当没有直接比较它们时,它们是不相等的,因为它们的引用地址不相同。( 默认情况下,equals和==是一样的,比较引用类型的内存地址
)
class Demo { private String name; private String email; public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Demo demo = (Demo) o; return Objects.equals(name, demo.name) && Objects.equals(email, demo.email); } @Override public int hashCode() { return Objects.hash(name, email); } }
在生成多字段的hashCode时,使用了类型的Objects.hash这个方法,它的源码如下
public static int hashCode(Object a[]) { if (a == null) return 0; int result = 1; for (Object element : a) result = 31 * result + (element == null ? 0 : element.hashCode()); return result; }
@Test public void hashcode() { Demo demo1 = new Demo(); demo1.setName("zzl"); Demo demo2 = new Demo(); demo2.setName("zzl"); Assert.assertEquals(demo1.getName().hashCode(), demo2.getName().hashCode()); Assert.assertEquals(demo1.hashCode(), demo2.hashCode()); }