Vector簡介

Vector簡介

  1. Vector和ArrayList類似,基于Object數(shù)組方式實(shí)現(xiàn)
  2. Vector是同步訪問的,操作是線程安全的

源碼分析

jdk1.7.0_71

//保存Vector中的元素
protected Object[] elementData;
//Vector中存儲的元素個數(shù)
protected int elementCount;
//Vector容量自動增長的大小,此數(shù)值小于等于0,容量增長為2倍
protected int capacityIncrement;

Vector(int initialCapacity, int capacityIncrement) 初始容量和初始自動增長 構(gòu)造

public Vector(int initialCapacity, int capacityIncrement){}

Vector(int initialCapacity) 初始容量 ,自動增長2倍 構(gòu)造

public Vector(int initialCapacity){}

Vector() 初始容量10,自動增長2倍 構(gòu)造

public Vector(){}

Vector(Collection<? extends E> c) 使用集合初始化

public Vector(Collection<? extends E> c){}

copyInto(Object[] anArray) 將Vector中的元素拷到Object數(shù)組中

public synchronized void copyInto(Object[] anArray) {}

trimToSize()

public synchronized void trimToSize() {} 

ensureCapacity(int minCapacity) 增加容量

public synchronized void ensureCapacity(int minCapacity) {}

grow(int minCapacity) 真正增長容量的方法

private void grow(int minCapacity) {}

setSize(int newSize) 設(shè)置大小

public synchronized void setSize(int newSize) {}

capacity() Vector的容量

public synchronized int capacity() {}

size() Vector包含元素的數(shù)量

public synchronized int size() {}

isEmpty()是否為空

public synchronized boolean isEmpty() {}

elements()返回一個枚舉

public Enumeration<E> elements() {
            return new Enumeration<E>() {
            int count = 0;

            public boolean hasMoreElements() {
                return count < elementCount;
            }

            public E nextElement() {
                synchronized (Vector.this) {
                    if (count < elementCount) {
                        return elementData(count++);
                    }
                }
                throw new NoSuchElementException("Vector Enumeration");
            }
        };
}

contains(Object o) 是否包含指定元素

public boolean contains(Object o) {}

indexOf(Object o) 返回第一個匹配的索引

public int indexOf(Object o) {}

indexOf(Object o, int index) 返回第一個從index開始的匹配的Object

public synchronized int indexOf(Object o, int index){}

lastIndexOf(Object o) 返回最后一個匹配的索引

public synchronized int lastIndexOf(Object o) {}

lastIndexOf(Object o, int index)返回最后一個從index開始的匹配的Object

public synchronized int lastIndexOf(Object o, int index) {}

elementAt(int index) 返回指定位置的元素

public synchronized E elementAt(int index) {}

firstElement() 第一個元素

public synchronized E firstElement(){}

lastElement() 最后一個元素

public synchronized E lastElement() {}

setElementAt(E obj, int index) 設(shè)置指定位置的元素

public synchronized void setElementAt(E obj, int index) {}

removeElementAt(int index) 移除指定位置的元素

public synchronized void removeElementAt(int index) {}

insertElementAt(E obj,int index)指定位置之后插入元素

public synchronized void insertElementAt(E obj, int index) {}

addElement(E obj) 添加元素到最后

public synchronized void addElement(E obj) {}

removeElement(Object obj) 刪除第一個匹配的元素

public synchronized boolean removeElement(Object obj) {}

removeAllElements() 刪除所有元素

public synchronized void removeAllElements() {}

clone() 深拷貝

public synchronized Object clone() {}

toArray() 返回Object數(shù)組

public synchronized Object[] toArray() {}

toArray(T[] a) 返回指定類型的數(shù)組

public synchronized <T> T[] toArray(T[] a) {}

elementData(int index) 返回指定位置的元素

E elementData(int index) {}

get(int index) 獲取指定位置的元素

public synchronized E get(int index) {}

set(int index, E element) 替換指定位置的元素

public synchronized E set(int index, E element) {}

add(E e) 添加元素到末尾

public synchronized boolean add(E e) {}

remove(Object o) 刪除第一個匹配的元素

public boolean remove(Object o) {}

add(int index, E element) 指定位置后面插入元素

public void add(int index, E element){}

remove(int index) 刪除指定位置的元素

public synchronized E remove(int index) {}

clear() 清空vector

public void clear() {}

containsAll(Collection<?> c) 是否包含指定的集合

public synchronized boolean containsAll(Collection<?> c) {}

addAll(Collection<? extends E> c) 把集合添加到vector的末尾

public synchronized boolean addAll(Collection<? extends E> c) {}

removeAll(Collection<?> c) 刪除vector中所有的指定集合中的元素

public synchronized boolean removeAll(Collection<?> c) {}

retainAll(Collection<?> c)保留指定的集合元素,其他的刪除

 public synchronized boolean retainAll(Collection<?> c) {}

addAll(int index, Collection<? extends E> c) 添加指定的集合元素到指定的位置之后

public synchronized boolean addAll(int index, Collection<? extends E> c) {}

equals(Object o)

public synchronized boolean equals(Object o) {}

hashCode()

public synchronized int hashCode() {}

toString()

public synchronized String toString() {}

subList(int fromIndex, int toIndex)返回一個子list

public synchronized List<E> subList(int fromIndex, int toIndex) {}

removeRange(int fromIndex, int toIndex) 刪除指定區(qū)間的元素

protected synchronized void removeRange(int fromIndex, int toIndex) {}

listIterator(int index)/listIterator() 返回一個ListIterator

public synchronized ListIterator<E> listIterator(int index) {}

public synchronized ListIterator<E> listIterator() {
        return new ListItr(0);
    }

iterator() 返回一個Iterator

public synchronized Iterator<E> iterator() {
        return new Itr();
    }

參考

http://www.cnblogs.com/skywang12345/p/3308833.html

http://www.runoob.com/java/java-vector-class.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,718評論 18 399
  • Collection ├List │├LinkedList │├ArrayList │└Vector │└Stac...
    AndyZX閱讀 963評論 0 1
  • 一、基本數(shù)據(jù)類型 注釋 單行注釋:// 區(qū)域注釋:/* */ 文檔注釋:/** */ 數(shù)值 對于byte類型而言...
    龍貓小爺閱讀 4,455評論 0 16
  • 當(dāng)我感覺有點(diǎn)旋暈 當(dāng)我感覺我還沒有完全脫離這個世界 能否借個肩膀, 借個懷抱 讓我像孩子一樣可以哭 讓我可以像孩子...
    右半邊愛情閱讀 230評論 1 1
  • 本章目錄 數(shù)據(jù)庫關(guān)系圖 檢索數(shù)據(jù) 排序數(shù)據(jù) 過濾數(shù)據(jù) 計(jì)算字段 數(shù)據(jù)處理函數(shù) 匯總數(shù)據(jù) 分組數(shù)據(jù) 子查詢 聯(lián)結(jié)表 ...
    趙太一閱讀 1,261評論 0 0

友情鏈接更多精彩內(nèi)容