一、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、分析源码