并发踩坑:list共享变量的addAll

背景:

某业务报错了,提示:Caused by: org.apache.ibatis.exceptions.PersistenceException:

Error querying database. Cause: java.util.ConcurrentModificationException

分析:

这是执行查询时报的 并发修改异常。大概逻辑是在多线程场景下,有一个共享变量list对象,每个线程都对它执行addAll操作。导致MySQL查询语句执行的时候,这个list还在并发修改,所以抛出的错误。

java 复制代码
public void restList() {
    
    Thread thread1 = new Thread("线程1"){
        @Override
        public void run() {
            innerSide();
        }
    };
    thread1.start();

    Thread thread2 = new Thread("线程2"){
        @Override
        public void run() {
            innerSide();
        }
    };
    thread2.start();                
    
}

public void innerSide(){
    List<String> list = nacos.getList();
    //List<String> list = new ArrayList<>();
    List<String> querys = mapper.selectList(queryWrapper);
    if(CollectionUtils.isNotEmpty(querys)){
        list.addAll(querys);
    }
    System.out.println(Thread.currentThread().getName() +JSONObject.toJSONString(list));

    List<Object> objectList = otherMapper.queryList(list);
}

代码逻辑如上所示,大概就是多个线程并发执行,调用innerSide()方法,但是这个方法里的list,是从nacos上读到的。所以list变量指向的是一个共享的引用地址。所以后续对list进行 addAll操作,每个线程都执行一次。导致list里的值呈指数级别增长。导致后边代码 otherMapper.queryList()方法执行的时候,mybatis报错并发修改。

修改:

list改成new的方式,不要用共享变量。

相关推荐
菜鸟233号10 分钟前
力扣416 分割等和子串 java实现
java·数据结构·算法·leetcode
求梦82029 分钟前
【力扣hot100题】缺失的第一个正数(12)
数据结构·算法·leetcode
黎雁·泠崖43 分钟前
二叉树实战进阶全攻略:从层序遍历到OJ题深度解析
c语言·数据结构·leetcode
散峰而望1 小时前
【算法竞赛】顺序表和vector
c语言·开发语言·数据结构·c++·人工智能·算法·github
cpp_25011 小时前
B3927 [GESP202312 四级] 小杨的字典
数据结构·c++·算法·题解·洛谷
Cx330❀1 小时前
《C++ 递归、搜索与回溯》第2-3题:合并两个有序链表,反转链表
开发语言·数据结构·c++·算法·链表·面试
独自破碎E1 小时前
链表相加(二)
数据结构·链表
CCPC不拿奖不改名1 小时前
面向对象编程:继承与多态+面试习题
开发语言·数据结构·python·学习·面试·职场和发展
꧁Q༒ོγ꧂1 小时前
算法详解(二)--算法思想基础
java·数据结构·算法
黎雁·泠崖1 小时前
二叉树综合拔高:遍历还原与OJ题拓展训练
c语言·数据结构·leetcode