ArrayList源码阅读

本文探讨ArrayList在Java中的使用,分析其作为集合的优势,如灵活性和存储对象的多样性,相较于数组的局限性。文章重点在于ArrayList的属性和构造方法,通过实例展示其功能。
摘要由CSDN通过智能技术生成

前言

       人生路很长,我们每个人的每一步都走的非常迷茫。但是,即使这样,我们依然要脚踏实地的向前走。今天,学习ArrayList组件中的属性及构造方法,小结一下。

为什么使用集合

       当我们需要保存一组类型相同的数据的时候,我们应该是用一个容器来保存,这个容器就是数组,但是,使用数组存储对象具有一定的弊端, 因为我们在实际开发中,存储的数据的类型是多种多样的,于是,就出现了“集合”,集合同样也是用来存储多个数据的。
       数组的缺点是一旦声明之后,长度就不可变了;同时,声明数组时的数据类型也决定了该数组存储的数据的类型;而且,数组存储的数据是有序的、可重复的,特点单一。 但是集合提高了数据存储的灵活性,Java 集合不仅可以用来存储不同类型不同数量的对象,还可以保存具有映射关系的数据。
       今天,主要学习了变量以及常用的构造方法,话不多说,上代码。

属性


    //默认的初始容量,且默认初始容量为10。
    private static final int DEFAULT_CAPACITY = 10;
    //用于空实例共享空数组实例。
    private static final Object[] EMPTY_ELEMENTDATA = {};
    //作用是将其与空元素的数据区分开,以知道何时去添加第一个元素。
    private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
    //存储ArrayList元素的数组缓冲区。
    //ArrayList的容量是这个数组缓冲区的长度。任何
    //elementData==DEFAULTCAPACITY_empty_elementData的空ArrayList
    //当添加第一个元素时,将扩展到默认的容量。
    //注意!这里使用transient,
    //transient作用是阻止被修饰的变量的值被序列化。
    transient Object[] elementData;
    //arrayList包含的元素数量。
    private int size;

构造方法

    public ArrayList(int initialCapacity) {
        //如果大于0是那么就将用户给的容量设置为数据缓冲数组的长度。
        if (initialCapacity > 0) {
            this.elementData = new Object[initialCapacity];
        } else if (initialCapacity == 0) {
            //如果初始容量为零,那么数据缓冲区就是一个空的数组。
            this.elementData = EMPTY_ELEMENTDATA;
        } else {
            throw new IllegalArgumentException("Illegal Capacity: "+
                                               initialCapacity);
        }
    }
    //当创建一个空的集合时,就有了默认容量,即为10。
    public ArrayList() {
        this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
    }
    //构造一个包含指定集合元素的列表,该列表按集合的迭代器返回的顺序排列。
    public ArrayList(Collection<? extends E> c) {
        //此构造方法是传递进来一个,然后传递进来之后,会将集合转换为数组
        //转换的过程是通过Arrays.copyof()方法复制了一个新的数组然后给到
        //当前当前数组。
        elementData = c.toArray();
        //如果存储数据的数组的长度等于集合的长度且不等于0
        if ((size = elementData.length) != 0) {
            //这里有一个bug是因为向下转型导致,因为当父类引用指向子类对象时
            //调用方法时默认调用的是子类中的方法,所以有可能返回的对象不与实际返回对象一致。
            if (elementData.getClass() != Object[].class)
                //如果返回的对象不是Object.class
                //就在复制一个数组,我理解的就是将类型转换,然后初始化当前数组。
                elementData = Arrays.copyOf(elementData, size, Object[].class);
        } else {
            //如果等于0则默认为空数组。
            this.elementData = EMPTY_ELEMENTDATA;
        }
    }

未完待续…
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值