equals()与hashcade()
equals()与hashcade()都是基类Object提供得方法,equals()比较两个引用对象是否引用同一对象;hashcode()返回对象的哈希值;
//返回对象的哈希值
public native int hashCode();
//本质和==一样
public boolean equals(Object obj) {
return (this == obj);
}
- hashcade()值相等的不一定是同一对象,不同对象哈希值一定不相等;
- equals()返回true时两引用一定引用同一对象;
- hashcade()操作简单,速度快;
- equals()操作相对复杂,速度慢
因为以上原因,所以equals()与hashcade()通常配合使用,两引用对象比较时,通常相比较其哈希值,哈希值相等,再做equals()比较,可节约时间开销。
问题一:那么什么情况需要重写equals()和hashcade() ?
一般情况不重写,当对象需要放到HashTable,HashMap,HashSet等hash结构的集合中时,才可能重写这两个方法;
问题二 :为什么重写equals方法必须重写hashcode方法呢?
java语言规范要求equals方法必须要满足以下几个特性:
- 自反性:x.equals(x) 结果 true;
- 对称性:x.equals(y) == y.equals(x)结果为true;
- 传递性:如果x.equals(y) 为true,y.equals(z)为true,那么x.equals(z)也为true
- 一致性:如果x,y引用的对象没有发生变化,反复调用x.equals(y)应该返回同样的结果;
- 对于任意非空引用x,x.equals(null)返回false;
由于以上特性,如果某个类没有重写hashcode方法的话,equals判断两个值相等,但是hashcode的值不相等,如 String类,这样就会造成歧义;