借用Map实现对List多线程处理结果排序

使用场景:在处理List存储的入参时,使用开启多线程处理,并使处理结果与入参顺序一致(即与List顺序一致)

解决思路:

1、将List转为请求Map,通过Map记录下标和入参,以下标为Key,入参为value;

2、将结果存入新建结果Map,Key为请求Map的Key(原List下标),value为处理结果值;

3、使用CountDownLatch,保证在进行重新排序时结果全部执行完毕;

4、新建结果List,通过对结果Map中的Key值进行重新排序。

public Result getFeeDesByTemplate(List list, String applyType) {
	Map<Integer, MultiPoolTradeResultDTO> tradeResultMap = getSaleGroupFeeDesByFeeTrade(list, applyType);
	Map<Integer, JSONArray> resultMap = new HashMap<>();
	// 线程资源共享
	RequestContextHolder.setRequestAttributes(RequestContextHolder.getRequestAttributes(), true);
	CountDownLatch countDownLatch = new CountDownLatch(tradeResultMap.size());
	for (Map.Entry<Integer, MultiPoolTradeResultDTO> entry : tradeResultMap.entrySet()) {
		// 异步处理
		new Thread(() -> {
			try {
				JSONArray jsonArray = new JSONArray();
				MultiPoolTradeResultDTO tradeResultDTO = entry.getValue();
				JSONObject tmpResult = queryRealSubjectFee(tradeResultDTO, applyType);
				if (!ObjectUtils.isEmpty(tmpResult)) {
					jsonArray.add(tmpResult);
				}
				resultMap.put(entry.getKey(), jsonArray);
			} catch (Exception e) {
				log.error(e.getMessage());
				throw new BusinessException(e.getMessage());
			} finally {
				countDownLatch.countDown();
			}
		}).start();
	}
	// 等待全部结束
	try {
		countDownLatch.await();
	} catch (Exception e) {
		log.error(e.getMessage());
		throw new BusinessException(e.getMessage());
	}
	List resultList = new ArrayList();
	for (int i = 0; i < resultMap.size(); i++) {
		resultList.add(i, resultMap.get(i));
	}
	return Result.ofSuccess(resultList);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值