java - hashmap中存进相同的key是后进的将前面的值覆盖掉,有没办法可以取到先存进的值?
阿神
阿神 2017-04-17 15:23:05
[Java讨论组]
mapss.put("name", "2");
mapss.put("name", "11");
System.out.println(mapss.get("name"));

比如这样,输出的是11,有没办法取到2这个值呢?
以前记得得存进hashmap是先计算key的hashcode值,如果发现该位置为空,则存进;如果不为空,则形成链表。
难道不是这样吗?求大神解释

阿神
阿神

闭关修行中......

全部回复(2)
ringa_lee

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

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

黄舟

没办法
两个key完全一样

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号