ArrayList 和 Vector

2018-07-03 15:24 更新

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

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

并且其中的數(shù)據(jù)是允許重復(fù)的

ArrayList與Vector的區(qū)別

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

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

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

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號