zoukankan      html  css  js  c++  java
  • 学习java8 流处理总结-根据条件筛选出新的集合

    1.很多情况我们需要在一个集合中筛选符合条件的形成一个新的数组

    一般情况可能就是使用一个for循环加if判断比如这样:

     List<DetailDataDto> detailDataDtos = basicInfoService.listDetailDataByDate(date, deptNo, t1);
    //筛选这个集合日期不为空,  getManpower 不为0,NaN,INFINITY
    //普通的可能首先创建一个新的集合为了接收复合条件的元素
     List<DetailDataDto> detailDataDtoStream  =new ArrayList<>();
    for(DetailDataDto detailDataDto:detailDataDtos){
        
    if(!detailDataDto.getManpower().equals(Double.NaN)||detailDataDto.getManpower().equals(Double.POSITIVE_INFINITY)||ObjectUtils.isNotEmpty(detailDataDto.getManpower())||ObjectUtils.isNotEmpty(detailDataDto.getDeployTime())){
    detailDataDtoStream.add(detailDataDto);
    }
    }
    //最后筛选出来才是自己想要的
     
    

     而看过流的操作可以使用以下形式来实现 不仅代码美观而且性能提高也不少

      List<DetailDataDto> detailDataDtos = basicInfoService.listDetailDataByDate(date, deptNo, t1);
         
            List<DetailDataDto> detailDataDtoStream =
                    detailDataDtos.parallelStream().filter(s -> !s.getManpower().equals(Double.NaN))
                            .filter(s -> !s.getManpower().equals(Double.POSITIVE_INFINITY))
                            .filter(s -> s.getManpower() != 0).filter(s -> ObjectUtils.isNotEmpty(s.getManpower()))
                            .filter(s -> ObjectUtils.isNotEmpty(s.getDeployTime())).collect(Collectors.toList());

    ps:parallelStream() 比stream 性能好点 这个是多线程处理;

  • 相关阅读:
    gradle平级项目引用
    java使用ssh访问Linux的项目jscraft
    debian更新源时找不到公钥的解决办法
    debian系在线安装软件apt-get命令族
    vim打造开发IDE
    Mysql主从同步配置
    byte[] 转Hex String
    记录一次条件比较多的SQL查询语句
    LruCache的缓存策略
    LinkedHashMap的实现原理
  • 原文地址:https://www.cnblogs.com/blackCatFish/p/12124334.html
Copyright © 2011-2022 走看看