CyclicBarrier 的用法

本文介绍CyclicBarrier在Java并发编程中的应用,通过示例展示如何使用CyclicBarrier来协调多个线程,确保所有线程在执行特定任务前相互等待,实现并行计算并汇总结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CyclicBarrier 的作用

  1. 假设有线程B、线程C、线程D
  2. BCD线程都需要执行到await方法后,才可以继续执行
  3. 总结:说白了就是,BCD线程要相互等待,都执行了await()方法才可以继续执行
    在这里插入图片描述
CyclicBarrier 例子:
	/**
	 * 实现功能是将goodsReqDtoList作为calcEstimateAmount方法的入参,然后将最终的结果放入map中进行返回
	 * 1.根据 goodsReqDtoList 的长度,判断我们要开多少个线程
	 * 2.将每个线程获得的结果放入 map 中,等到所有线程都计算完,将结果进行返回
	 * @param goodsReqDtoList CommonGoodsReqDto,支持多个商品属性的查询
	 * @return
	 */
	@Override
	public Map<String, Long> getRebatePlanAmount(List<CommonGoodsReqDto> goodsReqDtoList) {
		// 线程执行数量,判断要开多少个线程执行
		int threadNum;
		int everyListCount = 5; // 每个list中有5条数据
		if (goodsReqDtoList.size() % everyListCount == 0) {
			threadNum = goodsReqDtoList.size() / everyListCount;
		} else {
			threadNum = goodsReqDtoList.size() / everyListCount + 1;
		}

		final Map<String, Long> resMap = new ConcurrentHashMap<>();
		final CyclicBarrier cyclicBarrier = new CyclicBarrier(threadNum);
		List<CommonGoodsReqDto> goodsList = new ArrayList<>();
		for (int i = 0; i < goodsReqDtoList.size(); i++) {
			goodsList.add(goodsReqDtoList.get(i));
			if ((i == goodsReqDtoList.size() - 1) || (i + 1) % everyListCount == 0) {
				final List list = goodsList;
				new Thread(new Runnable() {
					@Override
					public void run() {
						// 将每个线程获得的结果放到 resMap 中
						resMap.putAll(calcEstimateAmount(list));
						try {
							cyclicBarrier.await();
						} catch (InterruptedException e) {
							e.printStackTrace();
						} catch (BrokenBarrierException e) {
							e.printStackTrace();
						}
						System.out.println("AAA");
					}
				}).start();
			}
			if ((i + 1) % everyListCount == 0) {
				goodsList = new ArrayList<>();
			}
		}
		return resMap;
	}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值