equals相等而hashCode是否一定相等的分析

时间:2020-12-23 16:11:55
 
原文地址: http://www.laozizhu.com/view.jsp?articleId=29

答案是不一定。因为equals到底如何工作,完全取决于你的方法是如何写的。
默认的集合的Hash实现才考虑hashCode,对于不使用Hash的操作,2个方法之间没有任何直接的关系。

比如如下的类
  1. import java.util.HashSet;
  2. import java.util.Set;
  3. /**
  4.  * equals相等而hashCode是否一定相等.
  5.  * 
  6.  * @author 老紫竹研究室(laozizhu.com)
  7.  * 
  8.  */
  9. public class Test {
  10.   public static void main(String[] args) {
  11.     TestEquals o1 = new TestEquals();
  12.     TestEquals o2 = new TestEquals();
  13.     System.out.println(o1.equals(o2));
  14.     System.out.println(o1.hashCode() == o2.hashCode());
  15.     // 我们测试一下HashSet
  16.     Set set = new HashSet();
  17.     set.add(o1);
  18.     set.add(o2);
  19.     set.add(o2);
  20.     set.add(o2);
  21.     System.out.println(set.size());
  22.   }
  23. }
  24. class TestEquals {
  25.   static int sequence = 1;
  26.   public boolean equals(Object obj) {
  27.     return true;
  28.   }
  29.   public int hashCode() {
  30.     return sequence++;
  31.   }
  32. }
运行结果
true
false
4

请一定注意那个4,而不是2;

结论:
2个方法是独立的,只不过在Hash操作时,会先根据hashCode进行分组,然后再对hashCode相同的根据equals判断是否找到。