hashCode与equals

hashCode的介绍

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

为什么会后hashCode

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

 

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

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

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

posted @   W_k  阅读(25)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示