ConcurrentHashMap的数据不一致问题

在多线程环境中,使用ConcurrentHashMap时遇到了数据不一致问题。问题出现在一个订单列表处理任务的场景,每个线程处理不同类型的订单任务。尽管尝试了使用synchronized关键字,但仍然无法保证数据一致性。分析发现,ConcurrentHashMap虽然使用分段锁提高并发性,但在并发写时可能存在不一致。解决方案是对contentMap的访问进行同步控制,确保数据正确同步。
摘要由CSDN通过智能技术生成

 

       ConcurrentHashMap被认为是支持高并发、高吞吐量的线程安全一个HashMap实现,因此多线程开发中经常使用到,但是最近在开发中却遇到了数据不一致问题,给自己埋了个大坑,下面描述下问题:

首先是工作场景描述:有一个订单列表,每个订单又包含多种类型的任务,每个线程一次只能处理一种类型的任务(取所有订单的该类型的任务,进行批量处理,任务没有先后关系),某订单处理完毕后,修改订单状态。

代码如下:

 

public class TaskRunner implements Runnable{

  //订单id列表
  private final List<String> orderList;
  //订单与任务类型列表对应关系,key是订单id,value是任务列表
  private final ConcurrentHashMap<String, List<String>> contentMap;  
  //所有的任务类型
  private final ConcurrentLinkedQueue<String> typeQueue;
  public TaskRunner(ConcurrentHashMap<String, List<String>> contentMap, 
      ConcurrentLinkedQueue<String> type, 
      List<String> orderList) {
    this.contentMap = contentMap;
    this.type
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值