在Jave中,每个对象都可以调用自己的hashcode()
方法得到自己的哈希值(hashCode
),相当于对象的身份证,通常来说世界上没有相同的身份证,但是在Java
中做不到这么绝对,但是我们仍然可以利用hashCode
来做一些提前的判断,比如:
- 如果两个对象的
hashCode
不相同,那么这两个对象肯定不同的两个对象 - 如果两个对象的
hashCode
相同,不代表这两个对象一定是同一个对象,也可能是两个对象 - 如果两个对象相等,那么他们的
hashCode
就—定相同
在Java的一些集合类的实现中,在比较两个对象是否相等时:
根据上面的原则,会先调用对象的hashCode()
方法得到hashcode
进行比较
如果hashcode
不相同,就可以直接认为这两个对象不相同
如果hashCode
相同,那么就会进一步调用equals()
方法进行比较。
而equals()
方法,就是用来最终确定两个对象是不是相等的,通常equals()
方法的实现会比较复杂,逻辑比较多,而hashCode()
主要就是得到一个哈希值,实际上就一个数字,相对而言比较简单,所以在比较两个对象时,通常都会先根据hashcode
比较一下。
所以我们就需要注意,如果我们重写了equals()
方法,那么就要注意hashCode()
方法,一定要保证能遵守上述规则。
如果重写
equals()
必须重写hashCode()
,比如在HashMap
中,key
如果是String
类型,String
如果只重写了equals()
而没有重写hashcode()
的话,则两个equals()
比较为true
的key
,因为hashcode
不同导致两个key
没有出现在一个索引上,就会出现map
中存在两个相同的key
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之家整理,本文链接:https://www.bmabk.com/index.php/post/104929.html