hashmap的扩容机制是什么?
时间: 2023-12-30 21:56:25 浏览: 30
HashMap的扩容机制是在当HashMap的元素个数达到容量的75%时,会进行扩容操作。具体扩容过程如下:
1. 新建一个大小为原数组两倍的数组newTable。
2. 将原数组中的元素重新计算hash值,并插入到newTable中。
3. 最后将HashMap的table指向newTable。
在插入元素时,如果发现当前元素个数已经达到了75%的容量,就会触发扩容操作,这个过程会比较耗费时间。因此,如果我们已经预知HashMap中元素的个数,可以通过构造函数直接指定初始容量,从而避免扩容操作带来的性能损耗。
相关问题
HashMap的扩容流程是什么?
HashMap的扩容流程如下:
1. 当HashMap中存储的键值对数量达到阈值时,即当前容量(数组长度)乘以负载因子(默认为0.75)时,会触发扩容操作。
2. 创建一个新的数组,长度为原数组长度的两倍。
3. 遍历原数组中的每个桶,将桶中的元素重新分配到新数组中对应的桶中。这个过程需要重新计算每个元素的哈希值并对新数组长度取模,以确定它应该被放置在哪个桶中。
4. 将新数组设置为HashMap的底层数组,并更新阈值(容量乘以负载因子)。
5. 扩容完成,HashMap重新可用。
需要注意的是,在扩容期间,HashMap可能会出现并发问题,因为在遍历旧数组并将元素移动到新数组时,可能会有其他线程同时对HashMap进行读写操作。为了解决这个问题,Java 8中引入了一种新的扩容机制,称为TreeBins。这种机制允许HashMap在扩容期间继续使用旧数组,同时在新数组中使用红黑树来保存元素,以避免在旧数组中的桶中出现链表过长的情况。
hashmap的扩容机制?list的扩容机制?
HashMap的扩容机制:
当HashMap中的元素个数达到了负载因子与当前容量的乘积时,就需要扩容。默认负载因子为0.75,即当元素个数达到容量的75%时就会触发扩容。具体扩容机制如下:
1. 创建一个新的Entry数组,长度是原来的2倍;
2. 将原Entry数组中的每个元素重新计算hash值,并放入新的Entry数组中。如果原Entry数组中有多个元素的hash值相同,那么会以链表的形式存储在新的Entry数组的同一位置上;
3. 将新的Entry数组赋值给原来的Entry数组,扩容完成。
List的扩容机制:
List是一个接口,具体的实现类有ArrayList和LinkedList,它们的扩容机制略有不同。
ArrayList的扩容机制:
当ArrayList中的元素个数达到了容量时,就需要扩容。扩容时会新建一个数组,将原数组中的元素复制到新数组中。具体扩容机制如下:
1. 创建一个新的数组,长度是原来的1.5倍;
2. 将原数组中的元素复制到新数组中;
3. 将新数组赋值给原来的数组,扩容完成。
LinkedList的扩容机制:
LinkedList并没有固定的容量,因此它并不需要扩容。当需要添加元素时,只需要在链表尾部添加一个节点即可。