优快云话题挑战赛第2期
参赛话题:学习笔记
前言
JDK8里,HashMap的数据结构是由数组+链表+红黑树组成。当1oldTable[index]1的链表元素达到8个时,若再添加元素,此时会尝试转换为红黑树。但是,如果,此时数组上所有元素(包括链表、红黑树)还未达到64时,仍然只是进行数组扩容。下面,就数组扩容过程中,旧数组中元素是如何移动至新数组的过程进行推演和总结。
一、场景
当数组发生扩容时,链表中所有元素需要移动至新数组相应位置。在JDK7中,是遍历链表,依次将元素移动至新数组相应位置。而在JDK8中,是将原有链表逻辑拆分成两个链表,移动将两个链表的头节点,直接放至新数组的相应下标位置。这里的思路与JDK7中的ConcurrentHashMap相似,只是实现不一样。
二、详细步骤
1.推演过程
数组扩容以及链表拆分的核心逻辑在源码的resize()方法,下面通过LinkTest链表的示例代码模拟,如下:
public class LinkTest {
private LinkTest next;
private int value;
private int hash;
public LinkTest(int value,LinkTest next,int hash){
this.value = value;
this.next = next;
this.hash = hash;//模拟key的hash值
}
public static void main(String[] args) {
mockJDK8(generate());
}
public static LinkTest generate(){
LinkTest tail = new LinkTest(55,null,1);
LinkTest l2 = new LinkTest(44,tail,1);
LinkTest l3 = new LinkTest(33,l2,2);
LinkTest l4 = new LinkTest(22,l3,2);
LinkTest l5 = new LinkTest(11,l4,1);
return l5;
}

本文解析JDK8中HashMap数组扩容时链表元素移动的内部逻辑,涉及链表拆分、新数组索引定位,并对比JDK7的处理方式。
最低0.47元/天 解锁文章
6820

被折叠的 条评论
为什么被折叠?



