HashMap是如何解决Hash碰撞的问题的?

HashMap是如何解决Hash碰撞的问题的?。小编来告诉你更多相关信息。HashMap是如何解决Hash碰撞的问题的今天分享:HashMap是如何解决Hash碰撞的问题的的相关经验,请看下面详细的介绍。首先

HashMap是如何解决Hash碰撞的问题的?。小编来告诉你更多相关信息。

HashMap是如何解决Hash碰撞的问题的

今天分享:HashMap是如何解决Hash碰撞的问题的的相关经验,请看下面详细的介绍。

首先要知道什么是Hash碰撞,通俗的讲就是当两个key运算出来的hash值与数组长度n-1进行与运算之后发现定位出来的位置是一样的。

这就是Hash碰撞、Hash冲突。

HashMap是如何解决Hash碰撞的问题的?

HashMap是通过在两个key计算出的同一个位置上挂一个链表,在这个链表放入多个元素。

让多个key-value对,同时放在数组的同一个位置上。

后面在get的时候,如果发现该位置挂了一个链表,只要遍历这个链表找到自己的key-value就可以了。

这里就会有一个性能问题?假设你的链表随着时间的推移变得很长,在后续遍历的时候,性能就会比较差,时间复杂度是O(n)。

所以HashMap做了一个优化,如果链表达到了一定的长度之后,会将其转换为红黑树,红黑树的好处就是遍历的时候时间间复杂度是O(logn),性能会比链表高一些。

上述分享的HashMap是如何解决Hash碰撞的问题的?的详细讲解,仅供大家参考建议!

本文内容由互联网用户自发贡献,该文观点仅代表作者本人。如发现本站有涉嫌抄袭侵权/违法违规的内容,请发送邮件至 97552693@qq.com 举报,一经查实,本站将立刻删除。本文链接:https://m.teaffka.com/n/4670.html

(0)
恰卡的头像恰卡
上一篇 2023年 9月 18日
下一篇 2023年 9月 18日

相关推荐

发表回复

登录后才能评论

联系我们

在线咨询: QQ交谈

邮件:97552693@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息