HashMap实现原理小结

最近面试,经常被问到是否了解java HashMap的实现原理,以前确实没有关注过。回来搜了搜,并了解了实现,结果回头去看源码,居然不一样了,再查相关资料,java8为了解决在hash冲突时优化hashmap查找速度,修改了实现算法。

hashmap实现原理

所有的key-value实体会以数组的形式存储,然后通过key的hashcode计算在数组存储位置,然后通过其存储位置提取或存储实体。在计算存储位置时,会出现不同hashcode的到相同存储位置,这个时候就会出现hash冲突。

java7采用的是链表形式解决hash冲突问题,会将新加入的实体放入链表头部,其next引用指向已存在实体,当链表变得很长的时候,要提取实体的话就要遍历链表,对比key值,造成性能下降

java8为了解决这个问题,当链表长度超过指定值8的时候,会将链表转换成二叉树结构,以提高查找速度


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值