HashMap的扩容机制?
时间: 2023-06-22 18:36:26 浏览: 94
当HashMap中的元素数量超过了负载因子和当前容量的乘积时,就会触发扩容操作。扩容操作会创建一个新的数组,数组的长度是原数组长度的两倍,然后将原数组中的元素重新分配到新数组中。具体步骤如下:
1. 创建一个新的数组,长度是原数组的两倍。
2. 遍历原数组中的每个元素,将其重新计算hash值,然后插入到新数组中的对应位置。
3. 将新数组设置为HashMap的table数组,原数组会被垃圾回收。
在重新分配元素时,由于元素的hash值可能会发生变化,因此需要重新计算元素在数组中的位置。如果新数组中的位置已经被占用了,那么就会发生冲突,此时采用链表的方式将元素放在已经占用的位置后面。如果链表的长度超过了8个元素,并且当前数组长度大于64,那么就会将链表转换为红黑树,以提高查找效率。
相关问题
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并没有固定的容量,因此它并不需要扩容。当需要添加元素时,只需要在链表尾部添加一个节点即可。
hashmap扩容机制
HashMap 是一种基于哈希表的数据结构,它通过哈希函数将键映射到存储桶中。当 HashMap 中添加元素时,如果该元素的数量超过了当前 HashMap 的容量,则需要进行扩容。
HashMap 扩容的机制如下:
1. 当 HashMap 中的元素个数超过了负载因子与当前容量的乘积时,就需要进行扩容(默认负载因子为 0.75)。
2. 扩容后的容量是原来的两倍,同时会重新计算哈希值并重新分配到新的存储桶中。
3. 扩容时,需要将原有的元素重新插入到新的存储桶中,这个过程需要花费一定的时间,因此扩容会带来一定的性能开销。
4. 在 Java 8 中,当链表长度达到 8 时,链表会自动转换为红黑树,以提高查找效率。
总之,HashMap 的扩容机制是为了保证其性能和空间利用率,当 HashMap 中的元素数量超过一定阈值时,就需要进行扩容,以便能够存储更多的元素。
阅读全文