谈谈你对HashMap中put/get方法的认识?如果了解再谈谈HashMap的扩容机制?默认大小是多少?什么是加载因子(或填充比)?什么是吞吐临界值(或阈值、threshold)?

本文探讨HashMap在JDK7中的put/get操作及其扩容机制。初始创建时,JDK8并不会立即分配数组,而是在首次put时创建长度为16的数组。当哈希冲突时,通过equals()判断键的相等性。若链表长度超过8且数组总长度超过64,JDK8将转为红黑树存储。负载因子默认为0.75,达到临界值12(16*0.75)时会扩容至原两倍。负载因子影响数据密度和查询性能,0.75是一个平衡点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

此图是jdk7的图解

jdk7的文字描述(会在中间介绍一些8的改变):

  • 将key1,value1(就是一个键值对Entry)添加到数组中,首先根据key1所在累的hashCode()方法计算key1的哈希值1,然后使用某种算法,得到哈希值2,(个人理解是两次计算哈希值是为了让得到的哈希值相同的概率更小些),哈希值2在使用indexFor()
    方法得到底层table数组中存放的位置:index(0<=index &&index <= 15);
    【1.在jdk8中,当使用了空参构造器创建对象时,底层并没有创建长度为16的数组,2.而是当我们首次调用put()函数时底层才会首先创建长度为16的数组,3.底层创建的数组为:Node[](classNode implements Map.Entry{},这里与jdk7有所不同】

  • 如果index位置没有元素,则直接把key1,value1这个键值对添加进去(添加成功1)

  • 如果index位置有元素(key2,value2)【我在这里只考虑只存在一对键值对,实际上是会存在多个键值对的,对应的把多个键值对考虑进来就好】,则比较key1和key2的哈希值。

--------------如果两者的哈希值不同,则(key1,value1)添加成功 (添加成功2)

--------------如果两者的哈希值相同,则调用key1所在类的e

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值