Java Stream() 整理 求和 汇总 分组 排序

reduce函数BigDecimal求和:

//list BigDecimal 求和
BigDecimal testBigDecimalValue = 
list.stream().map(a->a.get("key")).reduce(BigDecimal::add).orElse(BigDecimal.ZERO);
//int 
Integer testIntValue = 
list.stream().map(a->a.get("key")).reduce(Integer::sum).orElse(0);

summaryStatistics 获取 记录数 总和 均值 最大最小值:

        List<Map<String,Integer>> list = new ArrayList<>();
        Map<String,Integer> map = new HashMap();
        map.put("key",300);
        list.add(map);
        //获取 记录数 总和 均值 最大最小值
        list.stream().mapToInt((a)->a.get("key")).summaryStatistics().getCount();
        list.stream().mapToInt((a)->a.get("key")).summaryStatistics().getSum();
        list.stream().mapToInt((a)->a.get("key")).summaryStatistics().getAverage();
        list.stream().mapToInt((a)->a.get("key")).summaryStatistics().getMax();
        list.stream().mapToInt((a)->a.get("key")).summaryStatistics().getMin();

toList();

List list = Lists.stream().map(ceshiPojo::getId).collect(Collectors.toList());

list.sort 排序

         //日期排序为例            
         List<String> dateList = dateMap.values().stream().collect(Collectors.toList());
         dateList.sort((o1, o2) -> {
             DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyyy-MM");
             YearMonth ym1 = YearMonth.parse(o1, dtf);
             YearMonth ym2 = YearMonth.parse(o2, dtf);
             return ym1.atEndOfMonth().compareTo(ym2.atEndOfMonth());
         });

         //stream.sorted
         List<Pojo> list =           
         testList.stream().sorted(Comparator.comparing(Pojo::get排序字段))
         .collect(Collectors.toList());

.filter() 过滤list

list.stream().filter(user -> user .getId() == null)

.distinct() 去重

Collectors.groupingBy()分组

Map<String, List<Pojo>> collects = list.stream().collect(Collectors.groupingBy(pojo::pojo.getKey()/*分组后的key*/));

list转map

    //list转map
    userList.stream().collect(Collectors.toMap(User::getId, User::getName));
    /*
    *    Collector<T, ?, Map<K,U>> toMap(Function<? super T, ? extends K> keyMapper,
    *                                Function<? super T, ? extends U> valueMapper) {
    *    return toMap(keyMapper, valueMapper, throwingMerger(), HashMap::new);
    *    }
    */


    //参数 Function.identity() key:value 值是该对象本身
    list.stream().collect(Collectors.toMap(pojo::getkey字段, Function.identity(), (o1, o2)         
    -> o1));

Java9

挺详细的:Java 9 改进的 Stream API | 菜鸟教程

takeWhile() 方法在有序的 Stream 中,takeWhile 返回从开头开始的尽量多的元素;在无序的 Stream 中,takeWhile 返回从开头开始的符合 Predicate 要求的元素的子集

dropWhile 和 takeWhile相反 

ofNullable 方法可以预防 NullPointerExceptions 异常

上一篇:MybatisPlus整合


下一篇:mac_使用Charles抓取Firefox 链接