hashCode与equals

hashCode的介绍

hashCode()的作用是获取哈希码,也称为散列码,它返回的是一个int整数。这个哈希码的作用是确定该对象在哈希表中的索引位置。hashCode()是Object类中的方法,所以所有的类都包含有hashCode函数,散列表存储的是键值对,它的特点是:根据key快速的检索出对应的值。这其中就利用到了哈希码。

为什么会后hashCode

以hashSet为例,对象在加入HashSet时,HashSet会先计算对象的hashCode值来判断对象加入的位置,然后看该位置是否有值,没值就直接存储,有值就调用equals方法判断是否重复,如果相同就不存储,不相同的话重新散列到其他位置上存储,这样大大减少了equals的次数,提高了性能。

 

如果两个对象相等,那么hashCode一定相等。

两个对象hashCode相等,equals不一定相等。

如果没有重写hashCode方法,该class的两个对象的hashCode不相等。

posted @ 2022-05-09 17:49  W_k  阅读(23)  评论(0编辑  收藏  举报