HashCode:hashCode() 的作用是获取哈希码,也称为散列码;它实际上是返回一个int整数。这个哈希码的作用是确定该对象在哈希表中的索引位置。hashCode() 定义在JDK的Object.java中,这就意味着Java中的任何类都包含有hashCode() 函数。
equals:equals它的作用也是判断两个对象是否相等,如果对象重写了equals()方法,比较两个对象的内容是否相等;如果没有重写,比较两个对象的地址是否相同,价于“==”。同样的,equals()定义在JDK的Object.java中,
这就意味着Java中的任何类都包含有equals()函数。
(1)不会创建"类对应的散列表",这里所说的“不会创建类对应的散列表”是说:我们不会在HashSet, HashTable, HashMap等等这些本质是散列表的数据结构中,用到该类。例如,不会创建该类的HashSet集合。
注:在这种情况下,该类的“hashCode() 和 equals() ”没有半毛钱关系的!
equals() 用来比较该类的两个对象是否相等,而hashCode() 则根本没有任何作用,所以,不用理会hashCode()。
(2)会创建"类对应的散列表":这里所说的“会创建类对应的散列表”是说:我们会在HashSet, HashTable, HashMap等等这些本质是散列表的数据结构中,用到该类。例如,创建该类的HashSet集合。
在这种情况下,该类的“hashCode() 和 equals() ”是有关系的:
如果两个对象相等,那么它们的hashCode()值一定相同。这里的相等是指,通过equals()比较两个对象时返回true。
如果两个对象hashCode()相等,它们并不一定相等。因为在散列表中,hashCode()相等,即两个键值对的哈希值相等。然而哈希值相等,并不一定能得出键值对相等,此时就出现所谓的哈希冲突场景。
总结:HashCode和Equals的关系是,通过HashCode获取哈希码用来定位,确定对象在散列中的存储位置,然后再调用Equals方法来进行比较是否存在相等的对象(两个对象是否相等),如果只重写HashCode方法,而没有重写Equals方法,那么就无法判断两个
哈希码一样的对象是否是同一个对象;而如果只重写Equals方法,而没有重写HashCode方法,即使我们明明知道两个对象是相等,但是可能因为他们的的哈希码不一样,从而判断两个对象不相等。