码迷,mamicode.com
首页 > 编程语言 > 详细

Java-hashcode和equals方法

时间:2020-04-17 20:02:49      阅读:95      评论:0      收藏:0      [点我收藏+]

标签:hash算法   基于   个数   ash   需要   通过   shm   离散   二进制   

 

hashcode

hashcode()方法提供了对象的hashCode值,是一个native方法,返回的默认值与System.identityHashCode(obj)一致。

通常这个值是对象头部的一部分二进制位组成的数字,具有一定的标识对象的意义存在,但绝不定于地址。

作用是:用一个数字来标识对象。比如在HashMap、HashSet等类似的集合类中,如果用某个对象本身作为Key,即要基于这个对象实现Hash的写入和查找,那么对象本身如何实现这个呢?就是基于hashcode这样一个数字来完成的,只有数字才能完成计算和对比操作。

hashcode是否唯一

hashcode只能说是标识对象,在hash算法中可以将对象相对离散开,这样就可以在查找数据的时候根据这个key快速缩小数据的范围,但hashcode不一定是唯一的,所以hash算法中定位到具体的链表后,需要循环链表,然后通过equals方法来对比Key是否是一样的

equals与hashcode的关系

equals相等两个对象,则hashcode一定要相等。但是hashcode相等的两个对象不一定equals相等。

小结

hashcode是为了算法快速定位数据而存在的,而equals是为了对比真实值而存在的。

Java-hashcode和equals方法

标签:hash算法   基于   个数   ash   需要   通过   shm   离散   二进制   

原文地址:https://www.cnblogs.com/xingchong/p/12721982.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!