Java HashMap的底层实现

HashMap底层的结构,就是一个链表的数组
其中每一个链表称为一个“桶(Bucket)”。
HashMap可以很快地定位一个元素,因为它是按照键值对中Key元素的hashCode对桶的总数取余来决定存储到哪个桶去的,所以查找数据的时候同样的通过Key的元素的hashCode进行计算后,就可以知道元素的存储位置,然后通过数组可随机存取的特性,迅速地取到目标桶。如果桶内有不止一个的键值对,那么就要通过比较key是否相等来确定目标键值对了,但是由于范围已经缩小到一个桶内了,比较操作一般不用执行很多次。
HashMap创建的时候可以指定数组的大小(即桶的总数),以及加载因子(loadFactor)
加载因子决定了已使用的桶占到总数的多少百分比的时候,执行再散列操作进行扩容。默认值为0.75。

附一篇刚刚看到的总结比较详细的文章:HashMap的工作原理

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值