Java中的哈希表是通过HashMap类实现的。HashMap是基于哈希表的Map接口实现,它允许使用null值和null键。HashMap的扩容机制是在put()方法中实现的。
当向HashMap中添加元素时,首先会计算键的哈希值,然后根据哈希值找到对应的桶。如果该桶已经存在元素,那么会将新元素添加到链表或红黑树中。如果该桶为空,那么直接将元素添加到桶中。
在添加元素的过程中,HashMap会检查当前元素数量是否超过了阈值(容量 * 负载因子)。如果超过了阈值,那么就会触发扩容操作。扩容操作主要包括以下几个步骤:
-
计算新的容量:通常情况下,新的容量是原容量的两倍。如果原容量已经达到了最大容量(2^30),那么新的容量将保持不变。
-
创建新的桶数组:根据新的容量创建一个新的桶数组。
-
重新分配元素:遍历原桶数组,将每个桶中的元素重新计算哈希值,并放入新的桶数组中。这个过程可能会导致元素在新的桶数组中的位置发生变化。
-
更新容量和阈值:将新的容量和阈值更新到HashMap中。
需要注意的是,扩容操作是一个相对昂贵的操作,因为它涉及到重新分配元素和创建新的桶数组。因此,在使用HashMap时,应尽量避免频繁的扩容操作。可以通过设置合适的初始容量和负载因子来优化HashMap的性能。