ArrayList底层操作机制源码解析

 更新时间:2023年09月19日 10:59:36   作者:风过无痕2018  
这篇文章主要介绍了ArrayList底层操作机制源码解析,当创建ArrayList对象时,如果使用的是无参构造器,则初始elementData容量为0,第1次添加,则扩容elementData为10,如需要再次扩容,则扩容elementData为1.5倍,需要的朋友可以参考下

ArrayList 的底层操作机制源码

扩容机制:

  • ArrayList中维护了一个0bject类型的数组elementData. transient Object[] elementData; //transient表示瞬间,短暂的,表示该属性不会被序列化
  • 当创建ArrayList对象时,如果使用的是无参构造器,则初始elementData容量为0,第1次添加,则扩容elementData为10,如需要再次扩容,则扩容elementData为1.5倍。
  • 如果使用的是指定大小的构造器,则初始elementData容量为指定大小,如果需要扩容, 则直接扩容elementData为1.5倍。

debug源码

  • 使用无参构造器,创建和使用ArrayList源码
    /**
     * 创建一个空的elementData数组 = {}
     */
    public ArrayList() {
        this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
    }
   /**
	* 执行list.add方法, 先确定是否要扩容,再执行添加操作
	*/
    public boolean add(E e) {
    	// 每次都要看看是否需要扩容
        ensureCapacityInternal(size + 1); //ensureCapacityInternal:确认容量
        elementData[size++] = e;
        return true;
    }
   /**
	* 该方法确定minCapacity , 第一次扩容为10
	*/
   private void ensureCapacityInternal(int minCapacity) {
        if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) { 
            minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
        }
        ensureExplicitCapacity(minCapacity);
    }
   /**
	* modCount:记录当前集合被修改的次数,如果elementData的容量不够,就调用grow方法扩容
	*/
    private void ensureExplicitCapacity(int minCapacity) {
        modCount++; // modCount:记录当前集合被修改的次数,防止多线程操作出现的异常
        if (minCapacity - elementData.length > 0) 
        	// 如果elementData的容量不够,就调用grow方法扩容
            grow(minCapacity);
    }
   /**
	* 真的扩容,使用扩容机制来确定扩容到多大
	* 第一次newCapacity为10, 第二次及其以后按照1.5倍扩容
	* 扩容的是Arrays.copyOf(), 能保留以前的数据
	*/
    private void grow(int minCapacity) {
        // overflow-conscious code
        int oldCapacity = elementData.length;
        //(oldCapacity >> 1)的意思是oldCapacity / 2
        int newCapacity = oldCapacity + (oldCapacity >> 1); //(1.5倍扩容)
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity; //第一次就是10
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        // Arrays.copyOf 将 elementData{} 扩容为newCapacity大小
        elementData = Arrays.copyOf(elementData, newCapacity);
    }

方法一步步返回

  • 使用有参构造器,创建和使用ArrayList源码
   /**
	* 第一次就按照elementData的1.5倍扩容
	* 整个执行的流程和前面的无参构造的一样
	*/
    public ArrayList(int initialCapacity) {
        if (initialCapacity > 0) {
        	// 创建了一个指定大小的elementData数组 
            this.elementData = new Object[initialCapacity];
        } else if (initialCapacity == 0) {
            this.elementData = EMPTY_ELEMENTDATA;
        } else {
            throw new IllegalArgumentException("Illegal Capacity: "+
                                               initialCapacity);
        }
    }

整个执行的流程和无参构造的一样

到此这篇关于ArrayList底层操作机制源码解析的文章就介绍到这了,更多相关ArrayList源码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mvc架构实现商品的购买(二)

    mvc架构实现商品的购买(二)

    这篇文章主要为大家详细介绍了mvc架构实现商品购买功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • 简单总结Java的反射机制的运用

    简单总结Java的反射机制的运用

    这篇文章主要介绍了Java的反射机制的运用,对一些常用的类作了一些说明,需要的朋友可以参考下
    2015-11-11
  • SpringBoot实现简单文件上传功能

    SpringBoot实现简单文件上传功能

    这篇文章主要为大家详细介绍了SpringBoot实现简单文件上传功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • 解析spring-boot-starter-parent简介

    解析spring-boot-starter-parent简介

    本文通过代码的形式给大家介绍了spring-boot-starter-parent的基础知识,需要的朋友可以参考下
    2018-09-09
  • springboot使用filter获取自定义请求头的实现代码

    springboot使用filter获取自定义请求头的实现代码

    这篇文章主要介绍了springboot使用filter获取自定义请求头的实例代码,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • Java代码中如何设置输出字符集为UTF-8

    Java代码中如何设置输出字符集为UTF-8

    这篇文章主要介绍了Java代码中设置输出字符集为UTF-8,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • spring-gateway网关聚合swagger实现多个服务接口切换的示例代码

    spring-gateway网关聚合swagger实现多个服务接口切换的示例代码

    这篇文章主要介绍了spring-gateway网关聚合swagger实现多个服务接口切换的示例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • Java中StringBuilder常用构造方法解析

    Java中StringBuilder常用构造方法解析

    这篇文章主要介绍了Java中StringBuilder常用构造方法解析,StringBuilder是一个可标的字符串类,我们可以吧它看成是一个容器这里的可变指的是StringBuilder对象中的内容是可变的,需要的朋友可以参考下
    2024-01-01
  • JAVA面向对象 封装原理及实例解析

    JAVA面向对象 封装原理及实例解析

    这篇文章主要介绍了JAVA面向对象 封装原理及实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • Maven统一版本管理的实现

    Maven统一版本管理的实现

    在使用Maven多模块结构工程时,配置版本是一个比较头疼的事,本文主要介绍了Maven统一版本管理的实现,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03

最新评论