美文网首页
JDK1.8流式编程

JDK1.8流式编程

作者: 我知他风雨兼程途径日暮不赏 | 来源:发表于2020-05-27 16:27 被阅读0次

    1 生成流(Stream)

    在 Java 8 中, 集合接口有两个方法来生成流:

    • stream() − 为集合创建串行流。
    • parallelStream() − 为集合创建并行流。
    // stream(): 将strings List进行流化
    // filter(): 过滤处理,过滤规则为strings的元素不为空,即为空的从流中被剔除
    // collect(): 重新进行collect收集转成List。
    List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
    List<String> filtered = strings.stream().
      filter(string -> !string.isEmpty()).
      collect(Collectors.toList());
    

    输出:

    [abc, bc, efg, abcd, jkl]
    
    Process finished with exit code 0
    

    1.1 forEach方法

    Stream 提供了新的方法 'forEach' 来迭代流中的每个数据。

    //  forEach类似JAVA之前的for(String $ : strings)。
    List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
            strings.stream().forEach($ -> System.out.println($));
    

    输出:

    abc
    
    bc
    efg
    abcd
    
    jkl
    
    Process finished with exit code 0
    

    1.2 map方法

    map 方法用于映射每个元素到对应的结果。

     List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
            /***
             * map():相当于元素别名 -> 元素新值,value必须是和List中一致的泛型
             */
            strings.stream()
                    .map($ -> $+$)
                    .forEach($-> System.out.println($));
    

    输出:

    abcabc
    
    bcbc
    efgefg
    abcdabcd
    
    jkljkl
    
    Process finished with exit code 0
    

    1.3 filter方法

    filter 方法用于通过设置的条件过滤出元素。

    // stream(): 将strings List进行流化
    // filter(): 过滤处理,过滤规则为strings的元素不为空,即为空的从流中被剔除
    // collect(): 重新进行collect收集转成List。
    List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
    List<String> filtered = strings.stream().
      filter(string -> !string.isEmpty()).
      collect(Collectors.toList());
    

    输出:

    [abc, bc, efg, abcd, jkl]
    
    Process finished with exit code 0
    

    1.4 limit方法

    limit 方法用于获取指定数量的流。

     List<String> strings = Arrays.asList("abc", "bc", "efg", "abcd","", "jkl");
            /***
             * limit(number):相当于for(int i=0;i<number;i++)
             */
            strings.stream()
                    .map($ -> $+$)
                    .limit(2)
                    .forEach($-> System.out.println($));
    

    输出:

    abcabc
    bcbc
    
    Process finished with exit code 0
    

    1.5 sorted方法

    sorted 方法用于对流进行排序。

    List<String> strings = Arrays.asList("abc", "bc", "efg", "abcd","", "jkl");
            /***
             * sorted():正序排序
             * sorted(Comparator.reverseOrder()):倒序排序,也可在sorted()里自定义排序方法
             */
            strings.stream().sorted()
                    .forEach($-> System.out.println($));
            System.out.println("-----------分割线----------");
            strings.stream().sorted(Comparator.reverseOrder())
                    .forEach($-> System.out.println($));
    

    输出:

    abc
    abcd
    bc
    efg
    jkl
    -----------分割线----------
    jkl
    efg
    bc
    abcd
    abc
    
    
    Process finished with exit code 0
    

    1.6 Collectors 聚合

    Collectors 类实现了很多归约操作,例如将流转换成集合和聚合元素。

     List<String> strings = Arrays.asList("abc", "bc", "efg", "abcd","", "jkl");
     System.out.println(strings.stream()
                 .filter(s -> !s.equals(""))
                 .collect(toList()));
     System.out.println(strings.stream()
                 .collect(joining(",")));
    

    输出:

    [abc, bc, efg, abcd, jkl]
    abc,bc,efg,abcd,,jkl
    
    Process finished with exit code 0
    

    1.7 统计函数

    另外,一些产生统计结果的收集器也非常有用。它们主要用于int、double、long等基本类型上,它们可以用来产生类似如下的统计结果。

    List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);
    IntSummaryStatistics stats = numbers.stream().mapToInt(x->x).summaryStatistics();
    System.out.println("列表中最大的数 : " + stats.getMax());
    System.out.println("列表中最小的数 : " + stats.getMin());
    System.out.println("所有数之和 : " + stats.getSum());
    System.out.println("平均数 : " + stats.getAverage());
    

    输出:

    列表中最大的数 : 7
    列表中最小的数 : 2
    所有数之和 : 25
    平均数 : 3.5714285714285716
    
    Process finished with exit code 0
    

    1.8 reduce方法

    reduce:(T identity,BinaryOperator)/reduce(BinaryOperator)-可以先设置初始值,并将流中元素反复结合起来,得到一个值。

     List<Integer> numbers = Arrays.asList(3, 2, 2, 3, 7, 3, 5);
    System.out.println(numbers.stream().limit(3).reduce(0,(x,y)->x+y));
    

    输出:

    7
    
    Process finished with exit code 0
    

    2 灵活的运用

    2.1 简单的List转Map

    List<Integer> nums = Lists.newArrayList(1,2,3,1,10,2,3,10,10);
    
    Map<Integer,Integer> map2 =  nums.stream().distinct().map(num -> {
        return new ImmutablePair<Integer,Integer>(num,1);
    }).collect(Collectors.toMap(pair -> pair.left,pair -> pair.right));
    System.out.println(map2);
    
    ================================
    {1=1, 2=1, 3=1, 10=1}
    

    2.2 统计元素出现的次数

    List<Integer> nums = Lists.newArrayList(1,2,3,1,10,2,3,10,10);
    
    // 统计nums每个元素出现的次数
    Map<Integer,Integer> map = Maps.newHashMap();
    nums.stream().forEach(pair->{
        map.compute(
                 pair,(key, val) -> val = (val==null ? 1 : val+1)
        );
    });
    System.out.println(map);
    ------------------------------------------------
    {1=2, 2=2, 3=2, 10=3}
    
    Process finished with exit code 0
    

    2.3 将map转成同等val数量的key元素list

    // 将map中的key val转成同等val数量的key
    Map<Integer,Integer> map1 = Maps.newHashMap();
    map1.put(10,2);
    map1.put(3,1);
    map1.put(7,2);
    
    List list = map1.entrySet().stream().map(entry -> {
        return IntStream.range(0, entry.getValue()).mapToObj($ -> entry.getKey()).collect(Collectors.toList());
    }).flatMap(Collection::stream).collect(toList());
    ========================================
    [3, 7, 7, 10, 10]
    

    相关文章

      网友评论

          本文标题:JDK1.8流式编程

          本文链接:https://www.haomeiwen.com/subject/lvywahtx.html