Vector簡介

Vector簡介

  1. Vector和ArrayList類似,基于Object數(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)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市闺鲸,隨后出現(xiàn)的幾起案子筋讨,更是在濱河造成了極大的恐慌,老刑警劉巖摸恍,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件悉罕,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機壁袄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進店門类早,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人然想,你說我怎么就攤上這事莺奔。” “怎么了变泄?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵令哟,是天一觀的道長。 經(jīng)常有香客問我妨蛹,道長屏富,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任蛙卤,我火速辦了婚禮狠半,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘颤难。我一直安慰自己神年,他們只是感情好,可當我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布行嗤。 她就那樣靜靜地躺著已日,像睡著了一般。 火紅的嫁衣襯著肌膚如雪栅屏。 梳的紋絲不亂的頭發(fā)上飘千,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天,我揣著相機與錄音栈雳,去河邊找鬼护奈。 笑死,一個胖子當著我的面吹牛哥纫,可吹牛的內(nèi)容都是我干的霉旗。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蛀骇,長吁一口氣:“原來是場噩夢啊……” “哼奖慌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起松靡,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎建椰,沒想到半個月后雕欺,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年屠列,在試婚紗的時候發(fā)現(xiàn)自己被綠了啦逆。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡笛洛,死狀恐怖夏志,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情苛让,我是刑警寧澤沟蔑,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站狱杰,受9級特大地震影響瘦材,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜仿畸,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一食棕、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧错沽,春花似錦簿晓、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至镰禾,卻和暖如春皿曲,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背吴侦。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工屋休, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人备韧。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓劫樟,卻偏偏與公主長得像,于是被迫代替她去往敵國和親织堂。 傳聞我的和親對象是個殘疾皇子叠艳,可洞房花燭夜當晚...
    茶點故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容

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