一、ConcurrentModificationException
package com.example.mp.juc.unsafe;import java.util.ArrayList;
import java.util.List;
import java.util.UUID;
import java.util.concurrent.CopyOnWriteArrayList;/*** @author Mr.Lan* @version 1.0* @ClassName ListTest$* @description TODO* @date 2025/2/22 21:28**/
public class ListTest1 {public static void main(String[] args) {List<String> list = new ArrayList<>();for (int i = 0; i < 10; i++) {new Thread(()->{list.add(UUID.randomUUID().toString().substring(0,5));System.out.println(list);},String.valueOf(i)).start();}}
}
二、原因分析:
多个线程调用的时候(比如list),在读取的时候是固定的,但在写入的时候(可能存在覆盖操作)
三、常见的解决方案
1)vector、CopyOnWriteArrayList
2)使用Collections.synchronizedList封装
verctor原理:使用synchronized(效率低,因为只能允许一个线程操作)
CopyOnWriteArrayList原理: 写入的时候(可能存在覆盖操作) =====>读写分离的思想(写入时复制一份给调用者 调用者写完 直接插入即可【防止写入时覆盖,造成数据问题】)lock锁
源码:将整个列表复制一份然后插入数据 然后更新
学习方案记录:1、先回用 2、货比三家、找不同解决方案 3、分析源码