欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

ArrayList底层(JAVA8)

程序员文章站 2022-03-21 17:05:32
...

 

1.底层的成员变量

    //当创见的实例为空时,在添加元素时,设置默认大小为10
    private static final int DEFAULT_CAPACITY = 10;
    //用于空实例
    private static final Object[] EMPTY_ELEMENTDATA = {};
    //用于初始化
    private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
    //数组
    transient Object[] elementData; // non-private to simplify nested class access
    //数组的大小
    private int size;

2.创建未规定大小的数组实例时

当在创建实例没有设置大小时,系统会默认为空数组,当需要添加元素时,再调用方法进行判断,设置初始化值为10.

流程:

1.调用无参构造

public ArrayList() {
       //将对象初始化空数组
        this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
    }

2.在为其添加元素时:

ArrayList底层(JAVA8)

 首先对现在数组的长度进行判断:

ArrayList底层(JAVA8)

ArrayList底层(JAVA8) 

ArrayList底层(JAVA8)

 此时会默认设置大小为:10

2. 长度增加完成,然后就可以从0开始添加元素了,每添加一个size的大小会加1

当底层数组的长度大于10时,

ArrayList底层(JAVA8)

 ArrayList底层(JAVA8)

ArrayList底层(JAVA8)

 

底层长度1.5倍递增。(举例不成立,只是为了解释)

 

调用有参函数时:

ArrayList底层(JAVA8)

如果为0,则设置为空数组,其他按照参数设置长度。

当数组长度需要增加时,按照1.5倍的规则递增

 

 

相关标签: ArrayList