史上最牛逼手撕ArrayList源码

本文对比分析了JDK7和JDK8中ArrayList的创建方式,重点讲解了动态扩容机制的工作原理。JDK7预设容量,JDK8延迟初始化。讨论了ArrayList为何称为'动态'数组,以及扩容策略背后的计算逻辑。

ArrayList的源码分析:

ArrayList-----jdk7

第一步:ArrayList list = new ArrayList();

private static final int DEFAULT_CAPACITY = 10;

第二看:添加元素

public boolean add(E e) {
        ensureCapacityInternal(size + 1); 
        elementData[size++] = e;
        return true;
    }

第三看:扩容机制,为啥叫"动态"数组

(oldCapacity >> 1)右移一位,原来的0.5倍 oldCapacity + (oldCapacity >> 1) 所以再底层ArrayList自动扩容他的1.5倍就这么来的

private void grow(int minCapacity) {
        int oldCapacity = elementData.length;
    
        int newCapacity = oldCapacity + (oldCapacity >> 1);
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity;
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        elementData = Arrays.copyOf(elementData, newCapacity);
    }

扩容完了把原数组赋值给新数组

elementData = Arrays.copyOf(elementData, newCapacity);

开发中建议使用带参的构造器ArrayList list = new ArrayList(int capacity);

ArrayList-----jdk8

private static final Object[] EMPTY_ELEMENTDATA = {};

1、ArrayList list = new ArrayList();初始化时没有创建长度为10的数组

2、在第一次调用add时,才创建了长度为10 的数组

小结:

jdk7中ArrayList的对象的创建,一出来就给你弄好了数组。而jdk8中你要用才会去创建

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值