• 多线程使用之CompletableFuture


    public List<ComponentDataDTO> getComponentMinAndMaxData(String tableName, List<AnchorAndComponentDO> anchorAndComponentDOList, LocalDateTime startLocalDateTime, LocalDateTime endLocalDateTime) {
            List<ComponentDataDTO> componentDataDTOList = new ArrayList<>();
            ConcurrentHashMap<String,List<ComponentDataDTO>> componentDataDTOMap = new ConcurrentHashMap<>();
            if(anchorAndComponentDOList!=null && !anchorAndComponentDOList.isEmpty()){
                //多线程调用
                List<CompletableFuture<Boolean>> completableFutureList = anchorAndComponentDOList.stream().map((AnchorAndComponentDO anchorComponent)->
                        CompletableFuture.supplyAsync(()->{
                            try{
                                //调用处理
                                List<ComponentDataDTO> componentMinAndMaxDataList = componentMapper.getComponentMinAndMaxData(tableName, anchorComponent, startLocalDateTime, endLocalDateTime);
                                componentDataDTOMap.put(anchorComponent.getAnchorId()+":"+anchorComponent.getComponentId(),componentMinAndMaxDataList);
                            }catch (Exception e){
                                //记录备注Map
                                logger.error("监测点:"+anchorComponent.getAnchorId()+",监测项:"+anchorComponent.getComponentId()+",获取数据报错:"+e+"-"+e.getMessage());
                                return false;
                            }
                            return true;
                        })).collect(Collectors.toList());
                List<Boolean> collect = completableFutureList.stream().map(CompletableFuture::join).collect(Collectors.toList());
                if(!collect.contains(false)){
                    componentDataDTOMap.forEach((k, v) -> componentDataDTOList.addAll(v));
                }
            }
            return componentDataDTOList;
        }
  • 相关阅读:
    axios的封装
    单行和多行文本溢出省略号显示!!!
    vue2源码-响应式处理(学习笔记)-2
    vue2源码-rollup的配置(学习笔记)-1
    js的垃圾回收机制
    立即执行函数
    闭包笔记
    vue3.0的CompositionAPI
    Create gym environment with your own xml file and training it using her of baseline
    Brief introduction to mujoco or gym modeling using xml
  • 原文地址:https://www.cnblogs.com/panbingqi/p/14467663.html
Copyright © 2020-2023  润新知