高并发的异常之ConcurrentModificationException

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/m0_37294838/article/details/91609979
 1 故障现象
   java.util.ConcurrentModificationException
 
 2 导致原因
        线程不安全
 3 解决方法
    3.1 new Vector<>()
    3.2 Collections.synchronizedList(new ArrayList<>());
    3.3 new CopyOnWriteArrayList()
 写时复制(CopyOnWriteArrayList)

    1. CopyOnWrite容器即写时复制的容器。往一个容器添加元素的时候,不直接往当前容器Object[]添加,而是先将当前容器Object[]进行Copy,复制出一个新的容器Object[] newElements,然后新的容器Object[] newElements里添加元素,添加完元素之后,再将原容器的引用指向新的容器 setArray(newElements);。
这样做的好处是可以对CopyOnWrite容器进行并发的读,而不需要加锁,因为当前容器不会添加任何元素。所以CopyOnWrite容器也是一种读写分离的思想,读和写不同的容器

 public boolean add(E e)
 {
     final ReentrantLock lock = this.lock;
     lock.lock();

         try
 {
             Object[] elements = getArray();
             int len = elements.length;
             Object[] newElements = Arrays.copyOf(elements, len + 1);
             newElements[len] = e;
             setArray(newElements);
             return true;
         }
         finally {
            lock.unlock();
     }
 }
 */

猜你喜欢

转载自blog.csdn.net/m0_37294838/article/details/91609979
今日推荐