Vector 源码分析 jdk1.8

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vector 源码分析 jdk1.8相关的知识,希望对你有一定的参考价值。

Vector简介

Vector 是矢量队列,它是JDK1.0版本添加的类。继承于AbstractList,实现了List, RandomAccess, Cloneable这些接口。
Vector 继承了AbstractList,实现了List;所以,它是一个队列,支持相关的添加、删除、修改、遍历等功能
Vector 实现了RandmoAccess接口,即提供了随机访问功能。RandmoAccess是java中用来被List实现,为List提供快速访问功能的。在Vector中,我们即可以通过元素的序号快速获取元素对象;这就是快速随机访问。
Vector 实现了Cloneable接口,即实现clone()函数。它能被克隆。

和ArrayList不同,Vector中的操作是线程安全的

 

 

Vector的源码分析

  Vector 源码和 ArrAyList 基本一致, 。如需 ArrAyList 源码分析,详情请见  http://www.cnblogs.com/scholar-xie/p/7000082.html

 

  差异区别

  

  /**
     * synchronized*/
    public synchronized void addElement(E obj) {
        modCount++;
        ensureCapacityHelper(elementCount + 1);
        elementData[elementCount++] = obj;
    }

    /**
     *   synchronized  */
    public synchronized void removeAllElements() {
        modCount++;
        // Let gc do its work
        for (int i = 0; i < elementCount; i++)
            elementData[i] = null;

        elementCount = 0;
    }

  /**
     * 方法上面加上了 synchronized*/
    public synchronized E get(int index) {
        if (index >= elementCount)
            throw new ArrayIndexOutOfBoundsException(index);

        return elementData(index);
    }

 

  

以上是关于Vector 源码分析 jdk1.8的主要内容,如果未能解决你的问题,请参考以下文章

JavaSE面试题——基于JDK1.8中Vector的实现原理(源码剖析)

Java中HashMap底层实现原理(JDK1.8)源码分析

Java中HashMap底层实现原理(JDK1.8)源码分析

ReentrantLock源码分析--jdk1.8

ArrayList源码阅读分析(JDK1.8)

Java中HashMap底层实现原理(JDK1.8)源码分析