Java的List集合框架之Vector详细解析

 更新时间:2023年11月16日 09:53:25   作者:进击的猫  
这篇文章主要介绍了Java的List集合框架之Vector详细解析,List接口继承Collection,Collection继承于Iterable,List接口实现类分为Vector、ArrayList、LinkedList,Vector底层是一个Object数组,需要的朋友可以参考下

(一)List子父层级:

Vector继承关系

  • List接口继承Collection,Collection继承于Iterable;
  • List接口实现类分为:Vector、ArrayList、LinkedList;

(二)List实现类——Vector

1、Vector实现类

(1)Vector底层是一个Object数组,protected Object[] elementData;

(2)Vector中的所有涉及到Object数组的均是会加synchronized,列举常见方法:构造方法、add、remove、get、set等

(3)Vector中的默认容量为10,且扩容默认为当前容量翻倍(直接相加或者构造方法中指定扩容大小)。

2、常见源码:

(1)构造方法:

//无参构造
 public Vector() {
        this(10);//默认大小为10
    }

//初始化指定大小的有参构造方法
        public Vector(int initialCapacity) {
            this(initialCapacity, 0);
        }

//指定扩容大小和初始值的有参构造   
public Vector(int initialCapacity, int capacityIncrement) {
    super();//父类无参构造
    if (initialCapacity < 0)
        throw new IllegalArgumentException("Illegal Capacity: "+
                                           initialCapacity);
    this.elementData = new Object[initialCapacity];//实例化存储数组
    this.capacityIncrement = capacityIncrement;//设置自动扩容大小
}

(2)add方法:

/*
* 此处列举的直接末尾添加add方法,还有指定位置添加insertElementAt方法添加,操作数组均会在方法上添加synchronized锁
**/
public synchronized boolean add(E e) {
    modCount++;//操作次数
    ensureCapacityHelper(elementCount + 1);//是否需要扩容
    elementData[elementCount++] = e;//存储数据
    return true;
}
//扩容判定
private void ensureCapacityHelper(int minCapacity) {
 if (minCapacity - elementData.length > 0)//判定是否需要扩容,当前存入值已大于数组大小
     grow(minCapacity);//调用扩容方法
}

//数组最大值,使用Integer最大值2147483648-8,因数组需要存自身的元数据占用8位(Class\Lock\Flag\Size)
private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;

//扩容方法
private void grow(int minCapacity) {
    int oldCapacity = elementData.length;//当前数组大小
    //根据构造函数判定扩容值,未指定则采用翻一倍方式扩容
    int newCapacity = oldCapacity + ((capacityIncrement > 0)?capacityIncrement : oldCapacity);
    if (newCapacity - minCapacity < 0)//判定新扩容值是否满足当前存入后的数组大小
        newCapacity = minCapacity;//扩容大小不满足,则直接扩容到满足存入后的数组大小
    if (newCapacity - MAX_ARRAY_SIZE > 0)//判定扩容后的值是否大于数组最大值
        newCapacity = hugeCapacity(minCapacity);
    elementData = Arrays.copyOf(elementData, newCapacity);//数组迁移复制
}
//存储最大值判定,超出限制则默认使用最大值
private static int hugeCapacity(int minCapacity) {
    if (minCapacity < 0) //越界
        throw new OutOfMemoryError();
    return (minCapacity > MAX_ARRAY_SIZE)?Integer.MAX_VALUE:MAX_ARRAY_SIZE;//返回最大值或者数组最大值
}

(3)remove方法:

/*
* 此处列举的返回boolean值的删除方法,还有直接删除指定索引的remove,
* 它直接在方法上添加synchronized锁,逻辑与具体删除一致
**/
public boolean remove(Object o) {
    return removeElement(o);//调用具体删除方法
}

public synchronized boolean removeElement(Object obj) {
    modCount++;//操作次数
    int i = indexOf(obj);//获取obj在数组中存储的下标,防止数组越界
    if (i >= 0) {
        removeElementAt(i);//调用删除方法
        return true;
    }
    return false;
}
//索引寻找
public int indexOf(Object o) {
    return indexOf(o, 0);//传入需要比对值和数组首标
}
//遍历数组寻找指定值(找寻下标,防止线程不安全,加synchronized)
public synchronized int indexOf(Object o, int index) {
    if (o == null) {//判定传入是否为空
        for (int i = index ; i < elementCount ; i++)
            if (elementData[i]==null)
                return i;//返回数组下标第一个为null的索引
    } else {
        for (int i = index ; i < elementCount ; i++)
            if (o.equals(elementData[i]))//判定需要删除值与数组值是否相等,相等则返回第一个相等的下标
                return i;//返回索引值
    }
    return -1;
}
//根据索引对指定下标进行删除(与存储数组进行交互,添加synchronized锁)
public synchronized void removeElementAt(int index) {
    modCount++;//操作次数
    if (index >= elementCount) {//越界判定
        throw new ArrayIndexOutOfBoundsException(index + " >= " +
                                                 elementCount);
    }else if (index < 0) {//越界判定
        throw new ArrayIndexOutOfBoundsException(index);
    }
    int j = elementCount - index - 1;//计算需要被迁移的数组成员数量
    if (j > 0) {
        //使用系统类提供的数组复制方法进行迁移复制
        //参数说明:被复制的数组,被复制的数组起点下标,目标数组(复制到的新数组),目标数组被复制的起点下标,需要复制的大小
        System.arraycopy(elementData, index + 1, elementData, index, j);
    }
    elementCount--;//成员数量减1
    //将原来存储有值的最后一位值置为空,便于GC回收工作,提高内存使用率
    elementData[elementCount] = null;
}

(4)get方法:

public synchronized E get(int index) {
     if (index >= elementCount)//越界控制
         throw new ArrayIndexOutOfBoundsException(index);
     return elementData(index);
 }
 //返回指定数组值
 E elementData(int index) {
     return (E) elementData[index];
 }

(5)set方法:

public synchronized E set(int index, E element) {
   if (index >= elementCount)//越界控制
        throw new ArrayIndexOutOfBoundsException(index);
    E oldValue = elementData(index);//获取索引已存在的值或者null
    elementData[index] = element;//设置新值
    return oldValue;//返回设置之前的索引数组值
}

3、总结

(1)Vector是线程安全的,每个涉及到存储数据的方法都添加synchronized锁,性能相对会较低;

(2)Vector默认的存储大小为10,不指定自动扩容大小,则默认使用当前数组大小进行自加扩容(直接相加或者构造方法中指定扩容大小);      

到此这篇关于Java的List集合框架之Vector详细解析的文章就介绍到这了,更多相关List集合框架之Vector内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringMVC之返回JSON的三种方式

    SpringMVC之返回JSON的三种方式

    现在都是前后端分离了,后端只需要跟前端提供restful接口,所有接口都返回json格式数据即可,SpringMVC通常有3种方式向前端输出json格式数据,下面我们就来了解一下
    2023-06-06
  • SpringBoot自动配置原理及案例源码解析

    SpringBoot自动配置原理及案例源码解析

    这篇文章主要为大家介绍了SpringBoot自动配置原理及自动配置案例源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • Java中正则表达式匹配过程实例详解

    Java中正则表达式匹配过程实例详解

    正则匹配即是在给定字符串中查找符合正则表达式的字符,下面这篇文章主要给大家介绍了关于Java中正则表达式匹配过程的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-10-10
  • Arthas-java程序运行时debug工具使用

    Arthas-java程序运行时debug工具使用

    这篇文章主要介绍了Arthas-java程序运行时debug工具使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • 解决websocket 报 Could not decode a text frame as UTF-8错误

    解决websocket 报 Could not decode a text frame as UTF-8错误

    这篇文章主要介绍了解决websocket 报 Could not decode a text frame as UTF-8错误,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-10-10
  • 深入理解Spring Boot的日志管理

    深入理解Spring Boot的日志管理

    这篇文章主要给大家深入的介绍了Spring Boot日志管理的相关资料,文中介绍的很详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-02-02
  • Spring Cloud之配置中心的搭建

    Spring Cloud之配置中心的搭建

    这篇文章主要介绍了Spring Cloud之配置中心的搭建,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • Spring Boot Nacos 实现不停服发布过程详解

    Spring Boot Nacos 实现不停服发布过程详解

    这篇文章主要为大家介绍了Spring Boot Nacos实现不停服发布过程详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • Java FileDescriptor总结_动力节点Java学院整理

    Java FileDescriptor总结_动力节点Java学院整理

    FileDescriptor 是“文件描述符”。可以被用来表示开放文件、开放套接字等。接下来通过本文给大家分享Java FileDescriptor总结,感兴趣的朋友一起学习吧
    2017-05-05
  • 深入探究Java多线程并发编程的要点

    深入探究Java多线程并发编程的要点

    这篇文章主要介绍了深入探究Java多线程并发编程的要点,包括关键字synchronized的使用和wait()与notify()获取对象锁的三种方式,需要的朋友可以参考下
    2015-11-11

最新评论