Java学习 -- 简单分析ArrayList实例化的过程

ArrayList作为List接口的实现类,是Java为我们提供的一个容器,它对应着数据结构中的顺寻表结构,并且提供了一组针对于表中元素的增删改查操作。这里主要是简单分析一下ArrayList实例化的过程,以及它的扩容机制,这可以有助于我们更加深刻的理解顺序表结构,以及更好的使用ArrayList。如果有不正确地方,还请大佬们可以指出。

实例化

ArrayList中提供了3种重载的构造器:
在这里插入图片描述

  1. ArrayList()
ArrayList<Integer> list = new ArrayList<>();

在这里插入图片描述

  1. ArrayList(int initialCapacity)

    指定初始化容量

List<Integer> list = new ArrayList<>(255);

在这里插入图片描述

  1. ArrayList(Collection<? extends E> c)

Collection的实现类作为参数实例化ArrayList对象,该构造器会将参数对象中存储的元素拷贝到实例化的ArrayList对象中。

Collection<Integer> collection = new ArrayList<>(1);
List<Integer> list = new ArrayList<>(collection);  // 参数的泛型必须是实例化对象指定的泛型或其子类

在这里插入图片描述

自动扩容

ArrayList()添加元素使用add()方法,该方法提供了几种重载形式,此处主要介绍add(E e)方法,以及在添加过程中的扩容机制。
在这里插入图片描述

总结

  1. ArrayList在实例化时,如果使用空参构造器指定初始化容量为0或者指定的集合为空集合(数组长度为0),则在初始化时默认指向了一个共享的空数组,长度为0。这是JDK8.0之后的改变,目的是节省资源。
  2. 当第一次添加元素时,才会在底层为该对象创建数组。如果使用空参构造器实例化list,则数组默认容量为10。
  3. 如果是其它另外两种情况,则数组默认容量为1。(size + 1)
  4. 当需要扩容时,会对数组进行1.5倍的扩容。

建议:在开发中使用带参构造器:ArrayList(int capacity);,目的是为了防止数组频繁扩容,提高效率。

  • 11
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值