Java中Vector和ArrayList的區別
首先看這兩類都實現List介面,而List介面一共有三個實現類,分別是ArrayList、Vector和LinkedList。List用於存放多個元素,能夠維護元素的次序,並且允許元素的重複。3個具體實現類的相關區別如下:
ArrayList是最常用的List實現類,內部是透過陣列實現的,它允許對元素進行快速隨機訪問。陣列的缺點是每個元素之間不能有間隔,當陣列大小不滿足時需要增加儲存能力,就要講已經有陣列的資料複製到新的儲存空間中。當從ArrayList的中間位置插入或者刪除元素時,需要對陣列進行復制、移動、代價比較高。因此,它適合隨機查詢和遍歷,不適合插入和刪除。
Vector與ArrayList一樣,也是透過陣列實現的,不同的是它支援執行緒的同步,即某一時刻只有一個執行緒能夠寫Vector,避免多執行緒同時寫而引起的不一致性,但實現同步需要很高的花費,因此,訪問它比訪問ArrayList慢。
LinkedList是用連結串列結構儲存資料的,很適合資料的動態插入和刪除,隨機訪問和遍歷速度比較慢。另外,他還提供了List介面中沒有定義的方法,專門用於操作表頭和表尾元素,可以當作堆疊、佇列和雙向佇列使用。
檢視Java原始碼,發現當陣列的大小不夠的時候,需要重新建立陣列,然後將元素複製到新的陣列內,ArrayList和Vector的擴充套件陣列的大小不同。
ArrayList中:
1 public boolean add(E e) {
2
3 ensureCapacity(size + 1); // 增加元素,判斷是否能夠容納。不能的話就要新建陣列
4
5 elementData[size++] = e;
6
7 return true;
8
9 }
10
11 public void ensureCapacity(int minCapacity) {
12
13 modCount++;
14
15 int oldCapacity = elementData.length;
16
17 if (minCapacity > oldCapacity) {
18
19 Object oldData[] = elementData; // 此行沒看出來用處,不知道開發者出於什麼考慮
20
21 int newCapacity = (oldCapacity * 3)/2 + 1; // 增加新的陣列的大小
22
23 if (newCapacity < minCapacity)
24
25 newCapacity = minCapacity;
26
27 // minCapacity is usually close to size, so this is a win:
28
29 elementData = Arrays.copyOf(elementData, newCapacity);
30
31 }
32
33 }
34
35
Vector中:
1 private void ensureCapacityHelper(int minCapacity) {
2
3 int oldCapacity = elementData.length;
4
5 if (minCapacity > oldCapacity) {
6
7 Object[] oldData = elementData;
8
9 int newCapacity = (capacityIncrement > 0) ?
10
11 (oldCapacity + capacityIncrement) : (oldCapacity * 2);
12
13 if (newCapacity < minCapacity) {
14
15 newCapacity = minCapacity;
16
17 }
18
19 elementData = Arrays.copyOf(elementData, newCapacity);
20
21 }
22
23 }
24
25
關於ArrayList和Vector區別如下:
ArrayList在記憶體不夠時預設是擴充套件50% + 1個,Vector是預設擴充套件1倍。
Vector提供indexOf(obj, start)介面,ArrayList沒有。
Vector屬於執行緒安全級別的,但是大多數情況下不使用Vector,因為執行緒安全需要更大的系統開銷。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/1762/viewspace-2815667/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- java arrayList vector 區別Java
- LinkedList和ArrayList的區別、Vector和ArrayList的區別
- java複習之 Vector、ArrayList和LinkedList 的區別Java
- 【java】【集合】List的三個子類—ArrayList、Vector、LinkedList的區別和聯絡Java
- Java集合系列(二):ArrayList、LinkedList、Vector的使用方法及區別Java
- java中的List介面(ArrayList、Vector、LinkedList)Java
- java集合【12】——— ArrayList,LinkedList,Vector的相同點與區別是什麼?Java
- ArrayList和LinkedList的區別?
- ArrayList和LinkedList的區別
- Java List 常用集合 ArrayList、LinkedList、VectorJava
- std::vector 和 std::list 區別
- ArrayList和LinkedList的區別是什麼
- java 中equals和==的區別Java
- Difference Between Arraylist And Vector : Core Java Interview Collection QuestionJavaView
- java中==和equlas區別Java
- Java中 equals() 方法和 == 的區別Java
- ArrayList和LinkedList底層原理的區別和使用場景
- JAVA 中interface 和 abstract 區別Java
- java中size()和length區別Java
- 【java】【集合】去除ArrayList中的元素、ArrayList巢狀ArrayListJava巢狀
- 閒說: Java 中Comparable 和 Comparator 的區別Java
- ArrayList、LinkedList和Vector的原始碼解析,帶你走近List的世界原始碼
- java中Scanner類nextLine()和next()的區別和使Java
- 【Java】equals 和 == 的區別Java
- JAVA中字串比較equals()和equalsIgnoreCase()的區別Java字串
- 【Java面試】Spring中 BeanFactory和FactoryBean的區別Java面試SpringBean
- Java中抽象類和介面的區別Java抽象
- Java中異常分類和Throw和Throws的區別Java
- java yield()和sleep()的區別Java
- 深入探究Java中equals()和==的區別是什麼Java
- 【Java面試】Mybatis中#{}和${}的區別是什麼?Java面試MyBatis
- Java中(==)與equals的區別Java
- JavaScript中for in 和for of的區別JavaScript
- Js中for in 和for of的區別JS
- mysql中!=和is not的區別MySql
- Python中is和==的區別Python
- JavaScript中==和===的區別JavaScript
- Linux中“>”和“>>”的區別Linux