关于HashMap问题二

在最近参加的一次某国内知名公司实习生面试中,被问到了HashMap的底层实现,让我说一下,我当时说是散列表,然后把怎么存储,怎么取,什么比较hashcode,equals说了一堆,然后面试官问我,如果两个hashmap放了相同的一个key怎么办?

当时懵了。。。。。。

回来后看了下源码,发现这块是一个数组实现的,每一个hashmap会维护自己的一个entry数组,这个数组的大小必须是2的n次方,如果出现相同的hashcode时,则会用链表处理,entry类中有一个next指向了下一个entry,这样也就是说如果hashmap中元素hashcode均不同时查询速度可以达到o(1),但是,如果有用到entry的链表的话是需要遍历链表的,会降低hashmap的效率,所以在实现hashcode时,需要返回尽量不同的hashcode。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值