Java中Vector和ArrayList的區別

来源:http://www.cnblogs.com/chuangege/archive/2016/10/22/5987560.html
-Advertisement-
Play Games

首先看這兩類都實現List介面,而List介面一共有三個實現類,分別是ArrayList、Vector和LinkedList。List用於存放多個元素,能夠維護元素的次序,並且允許元素的重覆。3個具體實現類的相關區別如下: 查看Java源代碼,發現當數組的大小不夠的時候,需要重新建立數組,然後將元素 ...


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

  1. ArrayList是最常用的List實現類,內部是通過數組實現的,它允許對元素進行快速隨機訪問。數組的缺點是每個元素之間不能有間隔,當數組大小不滿足時需要增加存儲能力,就要講已經有數組的數據複製到新的存儲空間中。當從ArrayList的中間位置插入或者刪除元素時,需要對數組進行複製、移動、代價比較高。因此,它適合隨機查找和遍歷,不適合插入和刪除。
  2. Vector與ArrayList一樣,也是通過數組實現的,不同的是它支持線程的同步,即某一時刻只有一個線程能夠寫Vector,避免多線程同時寫而引起的不一致性,但實現同步需要很高的花費,因此,訪問它比訪問ArrayList慢。
  3. 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區別如下:

  1. ArrayList在記憶體不夠時預設是擴展50% + 1個,Vector是預設擴展1倍。
  2. Vector提供indexOf(obj, start)介面,ArrayList沒有。
  3. Vector屬於線程安全級別的,但是大多數情況下不使用Vector,因為線程安全需要更大的系統開銷。

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 基本特性: 線程共用區域,存儲被JVM載入的類信息、常量、靜態變數、即時編譯器編譯的代碼等 堆的邏輯部分,不限定方法去內的記憶體位置和編譯代碼的管理策略,不限定實現垃圾回收 容量可不定也可動態擴展,不要求物理連續 回收主要針對常量池的回收,和類型的卸載 HotSpot虛擬機方法區: 使用永久代實現方法 ...
  • Unrecognized Windows Sockets error: 0: JVM_Bind 異常解決辦法 java.net.SocketException: Unrecognized Windows Sockets error: 0: JVM_Bind 此異常的原因是伺服器埠被占用 所以解決辦 ...
  • 特性: 虛擬機啟動時創建的線程共用的記憶體區域,所有實例對象和數組對象分配記憶體的區域 GC垃圾手機管理器管理的主要區域,GC堆 容量可以固定,也可以動態擴展,自動收縮 -Xmx最大堆大小 -Xms最小、初始堆大小 所使用的記憶體不需要保證連續性,即不需要物理上的連續性,只需要邏輯上的連續性。 分配需要的 ...
  • 轉自:http://developer.51cto.com/art/201507/483510.htm 很多來自世界各地的程式員不求回報的寫代碼為別人造輪子、貢獻代碼、開發框架。開放源代碼使得分散在世界各地的程式員們都能夠貢獻他們的代碼與創新。 Python就是這樣一門受到全世界各地開源社區支持的語 ...
  • undefined reference to `WinMain@16'| 運行程式的時候出現了這樣的錯誤,而且編譯器也沒有提示是哪一行出錯: 經過百度搜索,發現了問題所在: 上面的圖中main()函數寫成了mian,編譯器提示的錯誤是:沒有發現main()函數。 ...
  • Java Virtual Machine Stacks,線程私有,生命周期與線程相同,描述的是Java方法執行的記憶體模型:每一個方法執行的同時都會創建一個棧幀(Stack Frame),由於存儲局部變數表、操作數棧、動態鏈接、方法出口等信息。每一個方法的執行就對應著棧幀在虛擬機棧中的入棧,出棧過程。 ...
  • 大家好!今天帶來的是自己實現的用C++實現的10以內整數的科學計算器,其中涉及中綴表達式到尾碼表達式(逆波蘭表示法),尾碼表達式的求值,涉及棧這一數據結構的壓棧,彈棧,存取棧頂元素和判斷棧是否為空等操作. 計算器在生活中應用廣泛.眾所周知,我們往計算器中輸入的是由數字,運算符組成的表達式,這個表達式 ...
  • 內部類不是很好理解,但說白了其實也就是一個類中還包含著另外一個類 如同一個人是由大腦、肢体、器官等身體結果組成,而內部類相當於其中的某個器官之一,例如心臟:它也有自己的屬性和行為(血液、跳動) 顯然,此處不能單方面用屬性或者方法表示一個心臟,而需要一個類 而心臟又在人體當中,正如同是內部類在外部內當 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...