map怎么实现hashcode和equals,为什么重写equals必须重写hashcode

HashMap:链表+数组方式实现。

HashMap的存储: 先从通过key的hascode计算出位置,然后存入到链表。

HashMap查找key: hashMap会先根据key值的hashcode经过运算定位其所在数组的位置,再根据key的equals方法匹配相同key值获取对应相应的对象.

也即是说,一个Key的查找是由hashcode和equals方法,共同来决定的。如果只实现equals, 而不实现hashcode。那么必然存着问题。

部分源码:

if (first.hash == hash && // always check first node
                ((k = first.key) == key || (key != null && key.equals(k))))
                return first;

 

equals 和 hascode是Java对象的两个方法。默认实现是:equals,比较两个对象的内存地址。hashcode,通过对象的内存地址计算出的散列值。 如果两个对象相等,hashcode一定相等。

当对某类equals重写之后,两个对象实例的内存地址不一定相同,而hashcode也不一定相同。 根据hashcode的规则,两个对象相等其hashcode一定相等,所以矛盾就产生了,因此重写equals一定要重写hashcode。

转载于:https://my.oschina.net/leegq/blog/3074556

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值