淺談Vector

Vector結(jié)構(gòu)圖
Vector.png
Vector主要方法
  • public synchronized boolean add(E e);
  • public synchronized E set(int index, E element) ;
  • public synchronized E get(int index);
  • public boolean remove(Object o);
Vector解讀主要方法

來(lái)看一下public synchronized boolean add(E e)源碼

//首先晌坤,需要說(shuō)明的是這個(gè)synchronized吧享,這是加鎖操作秃嗜,保證線程安全
public synchronized boolean add(E e) {
        modCount++;
        //確保容量
        ensureCapacityHelper(elementCount + 1);
        //添加元素橙垢,數(shù)量加一
        elementData[elementCount++] = e;
        return true;
    }
//這些操作和ArrayList的一致背犯,可以參考ArrayList
 private void ensureCapacityHelper(int minCapacity) {
        // overflow-conscious code
        if (minCapacity - elementData.length > 0)
            grow(minCapacity);
    }
private void grow(int minCapacity) {
        // overflow-conscious code
        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) // overflow
            throw new OutOfMemoryError();
        return (minCapacity > MAX_ARRAY_SIZE) ?
            Integer.MAX_VALUE :
            MAX_ARRAY_SIZE;
    }

來(lái)看一下public synchronized E set(int index, E element) 源碼

public synchronized E set(int index, E element) {
        //判斷index位置是否合理
        if (index >= elementCount)
            throw new ArrayIndexOutOfBoundsException(index);
        //獲取index位置老元素
        E oldValue = elementData(index);
       //替換index位置為新元素 
       elementData[index] = element;
        return oldValue;
    }

來(lái)看一下public synchronized E get(int index)源碼

public synchronized E get(int index) {
        //判斷index位置是否合理
        if (index >= elementCount)
            throw new ArrayIndexOutOfBoundsException(index);
          //獲取index位置元素
        return elementData(index);
    }

來(lái)看一下public boolean remove(Object o)源碼

//首先很奇怪的是這個(gè)方法沒(méi)有加鎖
  public boolean remove(Object o) {
        //來(lái)看一下真正的實(shí)現(xiàn)
        return removeElement(o);
    }
//其實(shí)還是加鎖了
public synchronized boolean removeElement(Object obj) {
        //修改modCount
        modCount++;
        //找到待刪除元素的位置
        int i = indexOf(obj);
        if (i >= 0) {
            //真正的刪除元素
            removeElementAt(i);
            return true;
        }
        return false;
    }
//刪除index
public synchronized void removeElementAt(int index) {
        modCount++;
         //判斷刪除位置是否合理
        if (index >= elementCount) {
            throw new ArrayIndexOutOfBoundsException(index + " >= " +
                                                     elementCount);
        }
        else if (index < 0) {
            throw new ArrayIndexOutOfBoundsException(index);
        }
        //確定需要移動(dòng)元素個(gè)數(shù)
        int j = elementCount - index - 1;
        if (j > 0) {
            //用index后一個(gè)元素覆蓋index玻墅,依次移動(dòng)装诡,一共移動(dòng)j個(gè)元素
            System.arraycopy(elementData, index + 1, elementData, index, j);
        }
        //總數(shù)減一吞歼,最后一個(gè)元素置空
        elementCount--;
        elementData[elementCount] = null; /* to let gc do its work */
    }

Vector遍歷介紹

常用的三種遍歷方式:

       //one  foreach  遍歷
        for (Object o : list) {
            System.out.println(o);
        }
        // two 隨機(jī)訪問(wèn)
        for (int i = 0; i <list.size(); i++) {
            System.out.println(list.get(i));
        }
        //three 迭代器的遍歷
        Iterator iterator = list.iterator();
        while (iterator.hasNext()){
            System.out.println(iterator.next());
        }
Vector其他特性介紹
  • 首先圈膏,vector是用數(shù)組實(shí)現(xiàn)的,所以ArrayList的數(shù)組特性vector也是有的篙骡,其次稽坤,vector是有synchronized鎖機(jī)制的,所以他是線程安全的糯俗,最后vector也會(huì)拋出ConcurrentModificationException這個(gè)異常尿褪。這個(gè)我有點(diǎn)不明白,為啥線程安全了還會(huì)拋出這個(gè)異常呢得湘?每次當(dāng)有線程做刪除操作的時(shí)候杖玲,就不應(yīng)該有線程可以去get或者set了呀! 這個(gè)問(wèn)題TODO處理淘正,希望有網(wǎng)友可以解決我的疑惑摆马。
  • vector默認(rèn)的初始值是10,private static final int DEFAULT_CAPACITY = 10;每次擴(kuò)容的容量為: int newCapacity = oldCapacity + (oldCapacity >> 1);約1.5倍
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末鸿吆,一起剝皮案震驚了整個(gè)濱河市囤采,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌惩淳,老刑警劉巖斑唬,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異黎泣,居然都是意外死亡恕刘,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門抒倚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)褐着,“玉大人,你說(shuō)我怎么就攤上這事托呕『兀” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵项郊,是天一觀的道長(zhǎng)馅扣。 經(jīng)常有香客問(wèn)我,道長(zhǎng)着降,這世上最難降的妖魔是什么差油? 我笑而不...
    開(kāi)封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上蓄喇,老公的妹妹穿的比我還像新娘发侵。我一直安慰自己,他們只是感情好妆偏,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布刃鳄。 她就那樣靜靜地躺著,像睡著了一般钱骂。 火紅的嫁衣襯著肌膚如雪叔锐。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天见秽,我揣著相機(jī)與錄音掌腰,去河邊找鬼。 笑死张吉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的催植。 我是一名探鬼主播肮蛹,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼创南!你這毒婦竟也來(lái)了伦忠?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤稿辙,失蹤者是張志新(化名)和其女友劉穎昆码,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體邻储,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡赋咽,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了吨娜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片脓匿。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖宦赠,靈堂內(nèi)的尸體忽然破棺而出陪毡,到底是詐尸還是另有隱情,我是刑警寧澤勾扭,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布毡琉,位于F島的核電站,受9級(jí)特大地震影響妙色,放射性物質(zhì)發(fā)生泄漏桅滋。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一身辨、第九天 我趴在偏房一處隱蔽的房頂上張望虱歪。 院中可真熱鬧蜂绎,春花似錦、人聲如沸笋鄙。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)萧落。三九已至践美,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間找岖,已是汗流浹背陨倡。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留许布,地道東北人兴革。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像蜜唾,于是被迫代替她去往敵國(guó)和親杂曲。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

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

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法袁余,類相關(guān)的語(yǔ)法擎勘,內(nèi)部類的語(yǔ)法,繼承相關(guān)的語(yǔ)法颖榜,異常的語(yǔ)法棚饵,線程的語(yǔ)...
    子非魚_t_閱讀 31,644評(píng)論 18 399
  • 一噪漾、基本數(shù)據(jù)類型 注釋 單行注釋:// 區(qū)域注釋:/* */ 文檔注釋:/** */ 數(shù)值 對(duì)于byte類型而言...
    龍貓小爺閱讀 4,265評(píng)論 0 16
  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問(wèn)題, 分享了一些自己做題目的經(jīng)驗(yàn)。 張土汪:刷leetcod...
    土汪閱讀 12,747評(píng)論 0 33
  • 總是 在回家的 路上 繞道 你的巷口 總是 在即將進(jìn)入時(shí) 又調(diào)轉(zhuǎn)了車頭 總是 在你臨街的窗前 忍不住的回頭 才想起...
    WMer閱讀 166評(píng)論 0 1
  • #每日500字#Day 11 作為新加入的婦委會(huì)的一員且蓬,三八節(jié)活動(dòng)突然就變成了我的事怪与,而知道這件事也就是節(jié)日前兩天...
    白米飯兒閱讀 848評(píng)論 0 0