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的性能差不多。

 
posted @ 2020-04-24 09:00  cnxieyang  阅读(11189)  评论(0编辑  收藏  举报
联系邮箱:cnxieyang@163.com