ArrayList 和 Vector

2018-07-03 15:24 更新

這兩個類都實現了List接口(List接口繼承了Collection接口).

他們都是有序集合,即存儲在這兩個集合中的元素的位置都是有順序的,相當于一種動態(tài)的數組

并且其中的數據是允許重復的

ArrayList與Vector的區(qū)別

  • Vector是線程安全的, 也就是線程同步的, 而ArrayList是線程序不安全的. 對于Vector&ArrayList, Hashtable&HashMap, 要記住線程安全的問題, 記住Vector與Hashtable是舊的, 是java一誕生就提供了的, 它們是線程安全的, ArrayList與HashMap是java2時才提供的, 它們是線程不安全的.

  • ArrayList與Vector都有一個初始的容量大小, 當存儲進它們里面的元素的個數超過了容量時, 就需要增加ArrayList與Vector的存儲空間, Vector默認增長為原來兩倍,而ArrayList的增長策略在文檔中沒有明確規(guī)定(從源代碼看到的是增長為原來的1.5倍).ArrayList與Vector都可以設置初始的空間大小, Vector還可以設置增長的空間大小, 而ArrayList沒有提供設置增長空間的方法.

總結:即Vector增長原來的一倍,ArrayList增加原來的0.5倍. Vector 線程安全, ArrayList 不是.

以上內容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號