【HashMap数组扩容时链表拆分过程】

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

优快云话题挑战赛第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;
    }    
   
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值