Java中Vector、ArrayList和LinkedList的區別

    from:http://www.cnblogs.com/wanlipeng/archive/2010/10/21/1857791.html

首先看這兩類都實現List接口,而List接口一共有三個實現類,分別是ArrayList、Vector和LinkedList。List用於存放多個元素,能夠維護元素的次序,並且允許元素的重複。3個具體實現類的相關區別如下:

  1. ArrayList是最常用的List實現類,內部是通過數組實現的,它允許對元素進行快速隨機訪問。數組的缺點是每個元素之間不能有間隔,當數組大小不滿足時需要增加存儲能力,就要講已經有數組的數據複製到新的存儲空間中。當從ArrayList的中間位置插入或者刪除元素時,需要對數組進行復制、移動、代價比較高。因此,它適合隨機查找和遍歷,不適合插入和刪除。
  2. Vector與ArrayList一樣,也是通過數組實現的,不同的是它支持線程的同步,即某一時刻只有一個線程能夠寫Vector,避免多線程同時寫而引起的不一致性,但實現同步需要很高的花費,因此,訪問它比訪問ArrayList慢。
  3. LinkedList是用鏈表結構存儲數據的,很適合數據的動態插入和刪除,隨機訪問和遍歷速度比較慢。另外,他還提供了List接口中沒有定義的方法,專門用於操作表頭和表尾元素,可以當作堆棧、隊列和雙向隊列使用。
  4. ArrayList和LinkedList的大致區別:

       1.ArrayList是實現了基於動態數組的數據結構,LinkedList基於鏈表的數據結構。

       2.對於隨機訪問get和set,ArrayList覺得優於LinkedList,因爲LinkedList要移動指針。

       3.對於新增和刪除操作add和remove,LinedList比較佔優勢,因爲ArrayList要移動數據
  5. 關於ArrayList和Vector區別如下:

    1. ArrayList在內存不夠時默認是擴展50% + 1個,Vector是默認擴展1倍。
    2. Vector提供indexOf(obj, start)接口,ArrayList沒有。
    3. Vector屬於線程安全級別的,但是大多數情況下不使用Vector,因爲線程安全需要更大的系統開銷
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章