码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【踩坑】parallel并发流导致数据异常


    【踩坑】parallel并发流导致数据异常

      • 1. 场景
      • 2. 代码
      • 3. 原因
      • 4. 总结

    1. 场景

    今天生产反馈有异常, 看看日志是CollectionUtils.sort空指针异常, 这一眼看就是list中的排序有空元素, 首先想到的是sql查出来的字段是否有null, 结果发现并没有, 再一看处理list, 就知道问题在哪了.

    2. 代码

    deptList.stream().limit(totalDept - 1)
    		.parallel()
            .forEach(
            	d -> list.add(new ClassVo(d.getDeptId(), d.getOrgName(), amtType)
         	);
    ...
            Collections.sort(list, Comparator.comparing(ClassVo::getDeptId));
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    3. 原因

    其实原因大概大家都知道, 并发修改导致的数据丢失呗,
    确实, 这个其实仔细一看就能发现有问题, 这个当时写的时候, 大概是因为后面有一个排序, 所以在stream流处理的时候是不需要关心list是否有序的, 所以就想用parallel处理快些, 但是具体问题出在哪, 直接看AbstractList对add的实现:

        public boolean add(E e) {
            add(size(), e);
            return true;
        }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5

    问题就在size方法不是线程安全的, 看看ArrayList的size实现:

     private int size;
     
        public int size() {
            return size;
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    假设A线程add的时候, size是3, B线程add的时候,size也是3,则两个线程都会往3的位置放入元素,就会覆盖数据, 导致最后数据丢失

    4. 总结

    1. 慎用parallel和parallelStream
    2. 如果非要用, 确保里面不会对同一个元素修改
    3. 如果非要修改, 确保元素是有同步修饰的, 或者Atomic类的
    4. 对于数据量不大的, parallel可能更耗时间, 因为线程的切换,以及parallel是先切分list再合并, 切分合并也需要时间
    5. parallel后会导致list无序
  • 相关阅读:
    【linux高性能服务器编程】中篇
    关于 国产麒麟系统运行Qt,在命令行可以运行而双击无法运行(无反应) 的解决方法
    非互联网客户收入近6成,阿里云进入新周期
    R语言安装与配置
    【教程】AWD中如何通过Python批量快速管理服务器?
    EasyRecovery适用于Windows和Mac的专业硬盘恢复软件
    win10 import rpy2 Unable to determine R home: [WinError 2]
    nmap参数详解
    DocuWare 文档管理系统Intelligent Indexing(智能索引)、 Forms(表单)和连接到Outlook 功能
    classification_report分类报告的含义
  • 原文地址:https://blog.csdn.net/zzzgd_666/article/details/128043327
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号