多线程问题,子线程同时操作全局变量,使用后需要清空吗 ?

在这里插入图片描述

背景:目前有一个全局变量
,某个方法中通过多线程,都操作这个变量,向这个全局变量中去添加元素,然后等所有子线程执行完了之后,对这个全局变量进行批量保存,然后这个全局变量还需要手动去清空吗?
?好像目前出现的情况,批量保存之后没有手动清空,导致下次再去使用这个List的时候,会在原来的基础上,叠加新元素!

现象确实是这样的;原因分析:

在多线程环境下操作全局的 List(如 finEodBalancePOS ),若批量保存后不手动清空,确实会导致后续使用时数据叠加,出现重复数据问题。以下从 问题本质是否需要清空正确清空方式 三个维度详细分析:

一、问题本质:全局变量的“状态残留”

// 全局/成员变量
List<FinCiticFlowPO> finEodBalancePOS = new CopyOnWriteArrayList<>();// 多线程添加元素
executor.submit(() -> {finEodBalancePOS.add(new FinCiticFlowPO(...));
});// 批量保存
finCiticFlowService.saveBatch(finEodBalancePOS);// 若不手动清空,下次使用时,List 仍保留之前的元素
  • 原因finEodBalancePOS 是全局/成员变量,其生命周期与类或应用一致。保存后数据不会自动消失,下次添加元素时会在原有数据基础上继续追加,导致重复数据。

二、是否需要手动清空?

必须手动清空,但要注意清空的时机

  • 错误时机:在多线程添加元素的过程中清空 → 会导致线程安全问题(如刚添加的数据被清空)。
  • 正确时机:批量保存成功后,确保数据已持久化到数据库,再清空 List

三、正确的清空方式(3种方案)

方案1:保存后直接清空(最简单)
// 批量保存
finCiticFlowService.saveBatch(finEodBalancePOS);// 保存成功后,清空 List
finEodBalancePOS.clear();
  • 优点:简单直接,适合“保存后立即复用 List”的场景。
  • 注意:需确保 saveBatch 方法执行成功(如无异常抛出),否则数据未保存就清空会丢失数据。
方案2:保存后创建新 List(避免多线程并发清空问题)
// 批量保存
finCiticFlowService.saveBatch(finEodBalancePOS);// 新建一个空 List 替换原变量(适合多线程可能同时操作的场景)
finEodBalancePOS = new CopyOnWriteArrayList<>();
  • 优点:通过“替换引用”的方式清空,避免多线程下 clear() 可能引发的并发修改问题(如其他线程还在添加元素时,clear() 会导致数据丢失 )。
  • 适用场景finEodBalancePOS 是全局变量,且可能被多个线程同时访问时。
方案3:结合 try-finally 确保清空(防止异常导致未清空)
try {// 批量保存finCiticFlowService.saveBatch(finEodBalancePOS);
} finally {// 无论保存是否成功,都尝试清空(需根据业务决定是否“失败也清空”)finEodBalancePOS.clear();// 或替换引用:finEodBalancePOS = new CopyOnWriteArrayList<>();
}
  • 优点:即使 saveBatch 抛出异常,也能执行清空操作,避免 List 因异常残留数据。
  • 注意:若业务要求“保存失败时保留数据以便重试”,则不能在 finally 中清空,需调整逻辑。

四、多线程场景下的安全清空

finEodBalancePOSCopyOnWriteArrayList(线程安全的 List 实现 ),clear() 本身是线程安全的,但仍需注意:

  • 清空时机:必须在所有子线程添加元素完成后清空,否则可能清空未处理完的数据。
  • 验证所有线程完成:可通过 CountDownLatchFuture 确保所有子线程执行完毕后,再执行保存和清空逻辑(参考之前的多线程异常处理方案 )。

五、总结

  • 必须手动清空:全局 List 不会自动清空,若不处理会导致数据叠加。
  • 清空时机:在批量保存成功后清空,确保数据已持久化。
  • 线程安全:若多线程同时操作 List,推荐用 CopyOnWriteArrayList 并在保存后替换引用(方案2),或严格保证清空时无线程写入。

按此逻辑调整后,就能避免下次使用 List 时数据重复叠加的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/92492.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/92492.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Netty知识储备:BIO、NIO、Reactor模型

学习Netty之前&#xff0c;首先先掌握这些基础知识&#xff1a;阻塞&#xff08;Block&#xff09;与非阻塞&#xff08;Non-Block&#xff09;&#xff0c;同步&#xff08;Synchronous&#xff09;与异步&#xff08;Asynchronous&#xff09;&#xff0c;Java BIO与NIO对比。…

用生成器守住架构,用 AI 放大效率:一套可落地的 AI 编程方法论

背景与问题 现实困境: 直接让 AI 产出整块业务代码&#xff0c;常常与现有架构风格、分层边界、依赖策略不一致&#xff0c;后续改造成本高&#xff1b;AI 对现实业务语境、领域规则难以精准把握&#xff1b;在既定模板成熟的场景下&#xff0c;代码生成器往往更快、更整齐。目…

码头岸电系统如何保障供电安全?安科瑞绝缘监测及故障定位方案解析

当岸电电网是TN-S系统时&#xff0c;船体未接专用接地线且船舶电网未与岸电零线接通&#xff0c;船舶电网发生单相接地故障时&#xff0c;人站在岸上触及船体会有触电危险&#xff0c;零线上可能出现高电压&#xff0c;单相接地电流大。当船体接专用接地线且船舶电网接入岸电零…

ESP32_u8g2移植

前言 U8g2 是一个用于嵌入式设备的单色图形库。U8g2支持单色OLED和LCD&#xff0c;并支持如SSD1306 SSD1315等多种类型的OLED驱动&#xff0c;几乎市面上常见都支持。 U8g2源码 download&#xff1a;https://github.com/olikraus/u8g21&#xff1a;环境 ESP32 S3(ESP32-S3-Dev…

MCP实现:.Net实现MCP服务端 + Ollama ,MCP服务端工具调用

本文使用.Net编写MCP服务端 Ollama &#xff0c;实现简单MCP调用&#xff0c;代码仅实现基本演示功能。 文章目录一、Ollama如何安装使用二、创建.Net8项目&#xff0c;开发MCP服务端三、开发MCP客户端&#xff0c;并对接Ollama一、Ollama如何安装使用 请移步&#xff1a;htt…

Docker的安装使用以及常见的网络问题

一、什么是DockerDocker是一种容器化技术&#xff0c;用于快速打包、分发和运行程序。他的核心思想是"一次构建&#xff0c;到处运行"&#xff0c;通过将应用及其依赖的环境打包到一个轻量级、可移植的容器中&#xff0c;实现跨平台一致运行。二、Docker的安装1.Cent…

C++入门学习

1.命名空间的介绍首先我们看到如下的代码&#xff0c;在C语言中&#xff1a;#include <stdio.h> #include <stdlib.h> int rand 10; // C语言没办法解决类似这样的命名冲突问题&#xff0c;所以C提出了namespace来解决 int main() {printf("%d\n", rand…

解决python错误:playwright._impl._errors.TimeoutError: Timeout 30000ms exceeded.

from playwright.sync_api import sync_playwrightwith sync_playwright() as p:browser = p.chromium.launch(headless=False)page = browser.new_page() page.goto(url)page.wait_for_load_state(networkidle) 在Python环境中运行以上代码后报错: page.wait_for_load_…

爬虫逆向之雷池waf

本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的。否则由此产生的一切后果均与作者无关&#xff01; 雷池waf概念 雷池 WAF&#xff08;SafeLine&#xff09;是长亭科技开源的一款 Web 应用防火墙&#xff0c;部署在网站前面&#xff0c;把所有进来的 HTTP/…

23种设计模式解析--行为型

行为型模式&#xff08;协作的艺术&#xff09; 观察者模式 观察者模式详解 模式定义 观察者模式&#xff08;Observer Pattern&#xff09;是一种行为设计模式&#xff0c;用于建立对象间一对多的依赖关系。当一个对象&#xff08;Subject&#xff09;状态变化时&#xff0c;所…

Linux系统之lua 详解

命令简介 lua 是 Lua 语言的解释器&#xff0c;用于加载和执行 Lua 程序&#xff08;包括文本源码和预编译的二进制文件&#xff09;。它支持两种运行模式&#xff1a;批处理模式&#xff08;执行指定脚本文件&#xff09;和交互式模式&#xff08;逐行读取并执行输入的命令&am…

visual studio 无明显错误,但是无法编译成功解决—仙盟创梦IDE

往后面查看rror CS0246: 未能找到类型或命名空间名“SimpleClass”(是否缺少 using 指令或程序集引用?)修复阿雪技术观在科技发展浪潮中&#xff0c;我们不妨积极投身技术共享。不满足于做受益者&#xff0c;更要主动担当贡献者。无论是分享代码、撰写技术博客&#xff0c;还是…

《论文阅读》传统CoT方法和提出的CoT Prompting的区分

论文&#xff1a;Chain-of-Thought Prompting Elicits Reasoning in Large Language Models作者对传统CoT方法和本文提出的CoT Prompting的区分。1. 传统方法的局限性 (1) 基于微调的CoT&#xff08;Rationale-Augmented Training&#xff09; 实现方式&#xff1a;需人工标注大…

Minio 高性能分布式对象存储

1、什么是对象存储? 描述: 对象存储&#xff08;Object Storage&#xff09;是一种存储数据的计算机体系结构&#xff0c;它以对象的形式存储和管理数据。与传统的文件系统和块存储不同&#xff0c;对象存储将数据作为对象存储在分布式的存储集群中&#xff0c;每个对象都有一…

[深度学习] 大模型学习4-RAG技术全景解析

在大语言模型基础知识一文中&#xff0c;检索增强生成&#xff08;Retrieval-Augmented Generation&#xff0c;简称 RAG&#xff09;技术作为构建大语言模型&#xff08;Large Language Model&#xff0c;简称 LLM&#xff09;应用的一种方式已被简要提及&#xff0c;本文将详…

4G/5G无线电单元系统

4G/5G无线电单元系统 ADI公司的核心技术和领域专业知识帮助客户在全球范围内规划、设计、打造更出色的高性能通信系统。 我们的无线电单元(RU)设计平台利用新一代技术来提供高性能解决方案&#xff0c;帮助客户消除设计障碍、缩短产品开发周期&#xff0c;加快产品上市时间。 价…

HarvardX TinyML小笔记1(番外2:神经网络)

1 介绍 图片来自&#xff1a;https://zh.wikipedia.org/zh-cn/%E4%BA%BA%E5%B7%A5%E7%A5%9E%E7%BB%8F%E7%BD%91%E7%BB%9C 神经网络一直感觉挺神奇的&#xff0c;江湖也说可解释性很差&#xff0c;无论如何还是学学吧。借这次学习哈佛的TinyML&#xff0c;也就顺带弄了。 这里…

计算机网络 第2章通信基础(竟成)

第 2 章 物理层【考纲内容】1.通信基础 (1) 信道、信号、带宽、码元、波特、速率、信源与信宿等基本概念 (2) 奈奎斯特定理与香农定理 (3) 编码与调制 (4) 电路交换、报文交换与分组交换 (5) 数据报与虚电路2.传输介质 (1) 双绞线、同轴电缆、光纤与无线传输介质&#xff1b;(2…

2025-08-09通过授权码的方式给exe程序充值

2025-08-09通过授权码的方式给exe程序充值主要点&#xff1a; 一次性授权机制&#xff1a; 新增 .used_licenses 文件记录所有已使用的授权码 每次激活前检查授权码是否在已使用列表中 激活成功后立即将授权码标记为已使用 时效性验证&#xff1a; 授权码包含过期时间戳&#x…

工具类-高效集合差异计算工具DiffWrapper

集合差异工具类-DiffWrapper 原因 在编辑过程中&#xff0c;肯定会存在对于子表的更新操作&#xff0c;这种更新分为三种&#xff1a; 要加的&#xff0c; 要删的&#xff0c;要更新的&#xff0c;并且传参只有一个modifyVO的, 每一个都写有点过于冗余&#xff0c;故考虑提取一…