1. 程式人生 > >arraylist、vector、linkedList的區別

arraylist、vector、linkedList的區別

tor arr 系列 mov enc 移除 操作 保存 插入

1、是否同步,看效率

arraylist 和linkedList是線程不安全的,vector是線程安全的。在不要求線程安全的情況下,使用arrayList和linkedList,可以節省同步帶來的開銷,運行效率高。在要求線程同步的情況下,要使用vector。

2.從底層看

從內部實現機制來講ArrayList和Vector都是使用Objec的數組形式來存儲的,當你向這兩種類型中增加元素的時候,如果元素的數目超出了內部數組目前的長度它們都需要擴展內部數組的長度,Vector缺省情況下自動增長原來一倍的數組長度,ArrayList是原來的50%,所以最後你獲得的這個集合所占的空間總是比你實際需要的要大。所以如果你要在集合中保存大量的數據那麽使用Vector有一些優勢,因為你可以通過設置集合的初始化大小來避免不必要的資源開銷。

三、檢索、插入、刪除對象的效率

ArrayList和Vector中,從指定的位置(用index)檢索一個對象,或在集合的末尾插入、刪除一個對象的時間是一樣的,可表示為O(1)。但是,如果在集合的其他位置增加或移除元素那麽花費的時間會呈線形增長:O(n-i),其中n代表集合中元素的個數,i代表元素增加或移除元素的索引位置。為什麽會這樣呢?以為在進行上述操作的時候集合中第i和第i個元素之後的所有元素都要執行(n-i)個對象的位移操作。
LinkedList中,在插入、刪除集合中任何位置的元素所花費的時間都是一樣的—O(1),但它在索引一個元素的時候比較慢,為O(i),其中i是索引的位置。
————————————————————————————————————————
一般大家都知道ArrayList和LinkedList的大致區別:
1.ArrayList是實現了基於動態數組的數據結構,LinkedList基於鏈表的數據結構。
2.對於隨機訪問get和set,ArrayList覺得優於LinkedList,因為LinkedList要移動指針。
3.對於新增和刪除操作add和remove,LinedList比較占優勢,因為ArrayList要移動數據。

ArrayList和LinkedList是兩個集合 類,用於存儲一系列的對象引用(references)。例如我們可以用ArrayList來存儲一系列的String或者Integer。那麽 ArrayList和LinkedList在性能上有什麽差別呢?什麽時候應該用ArrayList什麽時候又該用LinkedList呢?

arraylist、vector、linkedList的區別