HashCode和equal方法的区别和联系 [转]

HashCode 和 equal方法重载


1、 为什么要重载equal方法?

答案:因为Object的equal方法默认是两个对象的引用的比较,意思就是指向同一内存,地址则相等,否则不相等;如果你现在需要利用对象里面的值来判断是否相等,则重载equal方法。

2、 为什么重载hashCode方法?

答案:一般的地方不需要重载hashCode,只有当类需要放在HashTable、HashMap、HashSet等等hash结构的集合时才会重载hashCode,那么为什么要重载hashCode呢?就HashMap来说,好比HashMap就是一个大内存块,里面有很多小内存块,小内存块里面是一系列的对象,可以利用hashCode来查找小内存块hashCode%size(小内存块数量),所以当equal相等时,hashCode必须相等,而且如果是object对象,必须重载hashCode和equal方法。

3、 为什么equals()相等,hashCode就一定要相等,而hashCode相等,却不要求equals相等?

答案:1、因为是按照hashCode来访问小内存块,所以hashCode必须相等。

            2、HashMap获取一个对象是比较key的hashCode相等和equal为true。

之所以hashCode相等,却可以equal不等,就比如ObjectA和ObjectB他们都有属性name,那么hashCode都以name计算,所以hashCode一样,但是两个对象属于不同类型,所以equal为false。

4、 为什么需要hashCode?

1、 通过hashCode可以很快的查到小内存块。
2、 通过hashCode比较比equal方法快,当get时先比较hashCode,如果hashCode不同,直接返回false。

以下是一个具体类的实例代码:

 1 public class Person
 2 {
 3  private String name;
 4  private int age;
 5 
 6  @Override
 7  public int hashCode()
 8  {
 9   final int prime = 31;
10   int result = 1;
11   result = prime * result + age;
12   result = prime * result + ((name == null) ? 0 : name.hashCode());
13   return result;
14  }
15 
16  @Override
17  public boolean equals(Object obj)
18  {
19   if (this == obj)
20    return true;
21   if (obj == null)
22    return false;
23   if (getClass() != obj.getClass())
24    return false;
25   Person other = (Person) obj;
26   if (age != other.age)
27    return false;
28   if (name == null)
29   {
30    if (other.name != null)
31     return false;
32   } else if (!name.equals(other.name))
33    return false;
34   return true;
35  }
36 }

[转] http://hi.baidu.com/bluedream348/item/6f4fa3a468816ed85af1914e

原文地址:https://www.cnblogs.com/longdouhzt/p/2601859.html