CompletableFuture 处理List 并等待结果

 @Override
    @PMethodHandle(runMethodName = "dtMapDataRightList")
    public EntityResult dtMapDataRightList(Map<String, Object> mapParam) {
        // 查询所有大区
        List<Map<String, Object>> regionList = nodeRouterBaseMapper.findAllRegion();
        ThreadPoolExecutor executor = null;
        ArrayList<Map<String, Object>> result = null;
        try {
            executor = new ThreadPoolExecutor(3, 7, 15, TimeUnit.SECONDS, new ArrayBlockingQueue<>(5), new ThreadPoolExecutor.CallerRunsPolicy());
            result = new ArrayList<>();
            ArrayList<CompletableFuture<Void>> futureList = new ArrayList<>();
            for (Map<String, Object> map : regionList) {
                HashMap<String, Object> hashMap = new HashMap<>();
                CompletableFuture<Void> future = CompletableFuture.runAsync(() -> {
                    hashMap.put("region",map.get("lookupValueCode"));
                    // 获取大区下的省份
                    List<Map<String, String>> provinceList = nodeRouterBaseMapper.findProvinceByRegion(map.get("lookupValueCode").toString());
                    hashMap.put("province",provinceList);
                    // 统计RDC数量  查询RDC类型中转库的城市列表 ,size即为数量  城市用于统计覆盖城市数量
                    List<String> rdcCityList = nodeRouterBaseMapper.selectRdcOrFdcCount(provinceList, "RDC");
                    hashMap.put("rdcSum", rdcCityList.size());
                    // 统计FDC数量
                    List<String> fdcCityList = nodeRouterBaseMapper.selectRdcOrFdcCount(provinceList, "FDC");
                    hashMap.put("fdcSum", fdcCityList.size());
                    // 统计供应商数量
                    List<String> supplierCityList = nodeRouterBaseMapper.selectSupplierCount(provinceList);
                    hashMap.put("supplierSum", supplierCityList.size());
                    // 统计供应商覆盖城市数量
                    List<String> list = Stream.of(rdcCityList, fdcCityList)
                            .flatMap(Collection::stream)
                            .distinct()
                            .collect(Collectors.toList());
                    List<String> list2 = Stream.of(list, supplierCityList)
                            .flatMap(Collection::stream)
                            .distinct()
                            .collect(Collectors.toList());
                    hashMap.put("citySum", list2.size());
                }, executor);
                result.add(hashMap);
                futureList.add(future);
            }
            // 等待结果
            CompletableFuture.allOf(futureList.toArray(new CompletableFuture[0])).get(30000, TimeUnit.SECONDS);
            executor.shutdown();
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        } catch (ExecutionException e) {
            throw new RuntimeException(e);
        } catch (TimeoutException e) {
            throw new RuntimeException(e);
        }
        return ResultHelper.okEntity(result, "成功");
    }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值