HashMap 中的链表扩容机制主要包括以下几个步骤:
-
负载因子(load factor):HashMap 中的负载因子是一个重要的参数,它用于衡量 HashMap 的充满程度。当 HashMap 的元素数量超过容量与负载因子的乘积时,就会触发扩容操作。默认的负载因子是 0.75。
-
扩容阈值(resize threshold):当 HashMap 的元素数量达到扩容阈值时,就会进行扩容。扩容阈值 = 容量 * 负载因子。
-
扩容操作:当触发扩容时,HashMap 会创建一个新的数组,其大小是原数组的两倍。然后,将原数组中的元素重新分配到新数组中。这个过程称为 rehashing(重新哈希)。
-
重新哈希:在扩容过程中,需要对每个元素进行重新哈希。具体来说,是将元素的哈希值与新数组的容量进行按位与运算,得到新的索引位置。这样可以保证元素在新数组中的分布均匀,降低哈希冲突的概率。
-
处理链表:在 HashMap 中,当哈希冲突发生时,会将具有相同哈希值的元素存储在一个链表中。在扩容过程中,需要对链表中的元素进行重新分配。具体来说,是将链表中的元素重新计算哈希值,并将它们插入到新数组的相应位置。如果新数组的索引位置已经有元素,那么会将链表中的元素添加到该位置的链表头部。
-
完成扩容:当所有元素都重新分配到新数组中后,扩容操作完成。此时,HashMap 的容量和扩容阈值都会更新为新的值。
需要注意的是,HashMap 的扩容操作是一个相对昂贵的操作,因为它涉及到大量的元素重新分配和重新哈希。因此,在实际使用中,应该根据业务场景合理选择初始容量和负载因子,以尽量减少扩容操作的次数。