为了账号安全,请及时绑定邮箱和手机立即绑定

hashmap中存进相同的key是后进的将前面的值覆盖掉,有没办法可以取到先存进的值?

hashmap中存进相同的key是后进的将前面的值覆盖掉,有没办法可以取到先存进的值?

湖上湖 2019-02-21 01:24:10
mapss.put("name", "2"); mapss.put("name", "11"); System.out.println(mapss.get("name")); 比如这样,输出的是11,有没办法取到2这个值呢?以前记得得存进hashmap是先计算key的hashcode值,如果发现该位置为空,则存进;如果不为空,则形成链表。难道不是这样吗?求大神解释
查看完整描述

3 回答

?
缥缈止盈

TA贡献2041条经验 获得超4个赞

没办法
两个key完全一样

查看完整回答
反对 回复 2019-03-01
?
慕桂英3389331

TA贡献2036条经验 获得超8个赞

HashMap会先用key的hash值检查table 位置, 如果这个位置没有值就放入,如果有值,就用equals() 分别比较key 如果相等就替换该value 值。如果不等就放在链表的首位并next指针指向下一个entry

查看完整回答
反对 回复 2019-03-01
?
慕尼黑8549860

TA贡献1818条经验 获得超11个赞

你的理解不全面。HashMap会先用keyhash值来检查是否发生了hash碰撞,也就是对应的位置是否为空,这个没问题。问题是当发生了hash碰撞时,就会比较该位置上存储的每一个key是否与新存入的相等,如果相等就替换之,否则就在该位置增加一个值。很明显,你代码中的前后两个key是相同的,所以后面的会替换掉前面的。

所以HashMap的时间复杂度并不是O(1),如果碰撞比较“激烈”那么其性能就会降低,解决办法是增加容量,从而减小碰撞几率,性能自然也就变高了。也就是所谓的空间换时间的做法。

查看完整回答
反对 回复 2019-03-01
  • weixin_慕雪1585981
    weixin_慕雪1585981
    hashMap 当两个元素指向同一个地址的时候 会有一个entry类对象去维护,其中的参数有key value hash next 第二次put的元素确实会代替第一次的值,但是entry的next会指向原本的值
  • 3 回答
  • 0 关注
  • 2555 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信