ArrayList升級為線程安全的List


我們都熟知在高並發的場景下,ArrayList是線程不安全的,JDK Collections接口提供線程安全的操作,本文通過代碼演示下,最后查看源碼分析下為何是線程安全的。

ArrayList升級為線程安全的List 實例

  具體實現代碼如下,使用Collections工具類進行升級,如下圖

  

package com.yang.concurrent;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

/**
 * 本實例演示ArrayList升級為線程安全的List
 */
public class SyncArrayList {
    public static void main(String[] args) {
        List<Integer> list= Collections.synchronizedList(new ArrayList<>());
        list.add(1);
        System.out.println(list.get(0));
    }
}

  下面我們看下是如何包裝成安全的List

  

    public static <T> List<T> synchronizedList(List<T> list) {
        return (list instanceof RandomAccess ?
                new SynchronizedRandomAccessList<>(list) :
                new SynchronizedList<>(list));
    }

  ArrayList是實現了RandomAccess接口的,所以返回對象為:SynchronizedRandomAccessList,我們查看SynchronizedRandomAccessList相關方法實現,如下所示:

  

       public E get(int index) {
            synchronized (mutex) {return list.get(index);}
        }
        public E set(int index, E element) {
            synchronized (mutex) {return list.set(index, element);}
        }    

  我們發現在方法內部都是加了鎖的,實現和Vector類似

  由此我們可知:ArrayList包裝成線程安全的List后,和Vector的性能差不多。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM