1.维护 hashCode 方法的常规协定,该协定声明相等对象必须具有相等的哈希码。
2.hashcode是用于散列数据的快速存取,如利用hash结构集合类来存储数据时,都是根据存储对象的hashcode值来进行判断是否相同的。所以会出现一种可能,当重写equals方法后,判断对象相等,但其hashcode却不一致,这种相等可以看作为逻辑相等。当使用hash集合类时,存放时会根据该类的hashcode方法,来确定其存放位置,如hashset,将无法过滤相同对象,因为不重写hashcode,会默认调用Object类的hashcode方法,计算出来的存放地址不一样,会导致能同时存放两个值相等的对象,产生混淆。
public class Test{
public static void main(String[] args) {
persion p = new persion("1");
persion q = new persion("1");
System.out.println(p.equals(q));
HashSet hashSet = new HashSet();
hashSet.add(p);
hashSet.add(q);
System.out.println(hashSet.size());
}
}
class persion {
private String name;
public persion(String name) {
this.name = name;
}
public boolean equals(Object obj) {
if (obj instanceof persion) {
return name ==(((persion) obj).name);
}
return false;
}
/*public int hashCode() {
return name.hashCode();
}*/
}