集合--List接口的三种实现

本文详细介绍了Java集合中List接口的三种实现:ArrayList、Vector和LinkedList。ArrayList通过扩容机制实现元素添加,适合随机访问;Vector是线程安全的类,但效率较低;LinkedList作为双向链表,适合于频繁插入和删除操作。
摘要由CSDN通过智能技术生成
集合–List接口的三种实现
1.ArrayList实现类
public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess,
Cloneable, java.io.Serializable

内部实现:


transient Object[] elementData; 用于存储数据,体现ArrayList采用的是数组的方式提供实现

构造器:


//new ArrayList(1000);
public ArrayList(int initialCapacity) {
    //参数是初始化容积
 if (initialCapacity > 0) {
    如果容积初始值大于0则创建对应的对象
 this.elementData = new Object[initialCapacity];
 } else if (initialCapacity == 0) {
    如果容积值位0则创建一个空数组
 this.elementData = EMPTY_ELEMENTDATA;
 } else {
    如果小于0则抛出一个运行时异常
 throw new IllegalArgumentException("Illegal Capacity: "+ initialCapacity);
 }
}
//new ArrayList();
public ArrayList() {
    没有初始化参数值,则自动创建一个0个长的空数组
 this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA; }

add方法的实现


//向存储数据的elementData添加新元素
public boolean add(E e) {
   
 ensureCapacityInternal(size + 1); //确保内部容量,要求最小应该为【当前元素格式+1】,处理数组
elementData的长度,确保可以存放数据,如果当前数组长度不足,则需要增加数组长度。参数的含义是满足条件
的最小容积
 elementData[size++] = e; //将添加的元素存储数组,同时size+1
 return true; //如果添加过程中不出异常,则返回一定是true
}

ensureCapacityInternal方法:


private void ensureCapacityInternal(int minCapacity) {
   

ensureExplicitCapacity(calculateCapacity(elementData
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值