您的位置:首页 > 编程语言 > Java开发

[Java]HashMap的底层实现

2016-11-30 22:56 134 查看
HashMap底层的结构,就是一个链表的数组

其中每一个链表称为一个“桶(Bucket)”。

HashMap可以很快地定位一个元素,因为它是按照键值对中Key元素的hashCode对桶的总数取余来决定存储到哪个桶去的,所以查找数据的时候同样的通过Key的元素的hashCode进行计算后,就可以知道元素的存储位置,然后通过数组可随机存取的特性,迅速地取到目标桶。如果桶内有不止一个的键值对,那么就要通过比较key是否相等来确定目标键值对了,但是由于范围已经缩小到一个桶内了,比较操作一般不用执行很多次。

HashMap创建的时候可以指定数组的大小(即桶的总数),以及加载因子(loadFactor)

加载因子决定了已使用的桶占到总数的多少百分比的时候,执行再散列操作进行扩容。默认值为0.75。

附一篇刚刚看到的总结比较详细的文章:HashMap的工作原理
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java hashmap hashcode