Vector和SynchronizedList

ArrayList是非線程安全的集合類,如果在多線程的場景下使用ArrayList,比如一個線程遍歷ArrayList的時候,另一個線程修改ArrayList時,會報ConcurrentModificationException(并發(fā)修改異常)異常。解決方案一般有兩種,使用Vector或者SynchronizedList。

Vector

Vector是矢量隊列,和ArrayList一樣,繼承了AbstractList類,實現(xiàn)了List、RandomAccess(實現(xiàn)快速隨機訪問)、Cloneable、Serializable等接口。

public class Vector<E>
    extends AbstractList<E>
    implements List<E>, RandomAccess, Cloneable, java.io.Serializable

Vector是通過數(shù)組來保存數(shù)據(jù)的。Vector有4種構造函數(shù)。

// 第一種,默認大小為10
Vector()
// 第二種,指定向量的size
Vector(int size)
// 第三種,構造方法創(chuàng)建指定大小的向量,并且增量用 incr 指定。增量表示向量每次增加的元素數(shù)目。
Vector(int size,int incr)
// 第四種,創(chuàng)建一個包含集合 c 元素的向量
Vector(Collection c)

與ArrayList不同的是,Vector中的操作是線程安全的,因為Vector中的操作方法,都加了synchronized關鍵字修飾。但是正因為這個原因,使得Vector操作元素的效率很低。

SynchronizedList

SynchronizedList是SynchronizedCollection的子類,實現(xiàn)了List接口。SynchronizedList的get、add等方法,都加了synchronized關鍵字修飾,但是listIterator()和listIterator(int index)方法沒有加。所以在遍歷SynchronizedList的時候,需要放到synchronized修飾的代碼塊里。

List<String> list = Collections.synchronizedList(new ArrayList<String>());
list.add("1");
list.add("2");
list.add("3");

synchronized (list) {
    Iterator i = list.iterator(); 
    while (i.hasNext()) {
           System.out.println(i.next());
    }
}
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容