zoukankan      html  css  js  c++  java
  • 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的性能差不多。

     
  • 相关阅读:
    oracle恢复被覆盖的存储过程
    POJ 2478 Farey Sequence
    java不求有功,但求无过—异常处理
    图论-树的最大路
    MP3的频率、比特率、码率与音质的关系
    基于Lucene3.5.0怎样从TokenStream获得Token
    Groovy新手教程
    Binder机制1---Binder原理介绍
    UVA
    Hibernate Criterion
  • 原文地址:https://www.cnblogs.com/cnxieyang/p/12765204.html
Copyright © 2011-2022 走看看