美文网首页
Java 8:流操作(Stream)的三要素:数据源、中间操作和

Java 8:流操作(Stream)的三要素:数据源、中间操作和

作者: RealityVibe | 来源:发表于2019-10-06 13:01 被阅读0次

    流操作

    基本思想

    以声明性方式处理数据集合

    特性

    内部迭代

    与集合类操作不同的是,流会替我们把迭代做了,我们只需要关注对每个对象的具体操作。

    内部迭代与外部迭代

    流的分解

    一个完整的流操作 = 1 * 数据源 + n * 中间操作 + 1 * 终端操作

    终端操作就像是整个流操作的开关阀门,触发流水线执行并在执行完成后关闭流。

    由以上定义可以了解到流的三要素

    • 数据源、中间操作、终端操作

    中间操作

    会返回一个流,每个流都只能遍历一次。

    常见的中间操作有map、limit、filter、distinct、sorted。limit会截断流。

    • limit的短路操作
      public static void main(String[] args) {
            Set<Integer> set = new HashSet<Integer>() {{
                add(15);
                add(2);
                add(21);
                add(5);
                add(9);
                add(4);
                add(14);
                add(19);
                add(7);
            }};
            // 打印set中元素的顺序
            set.stream().forEach(System.out::println);
            System.out.println("-----------------------");
            
            // 筛选set中大于10的数字,只取前两个(limit(2)),并在遍历过程中打印被遍历的元素
            set.stream().filter(o -> {
                System.out.println(o);
                return o > 10;
            }).limit(2).sorted().forEach(System.out::println);
        }
    
    • 输出结果
    2
    19
    4
    21
    5
    7
    9
    14
    15
    -----------------------
    2
    19
    4
    21
    19
    21
    

    可以看到由于limit的存在,当程序找到两个大于10的数字(即19和21后,没有继续遍历下去)。limit会对流的遍历做优化。

    终端操作

    就像上文提到的,终端操作是整个流操作的开关,没有终端操作中间操作就不会执行。

    常见的终端操作有:collect、forEach、sum、count等

    对limit短路的例子做一下修改,去掉forEach这个终端操作,可以发现在输出结果中,没有遍历set时的打印信息,也就证明了这一点。

    // 筛选set中大于10的数字,只取前两个(limit(2)),并在遍历过程中打印被遍历的元素
    set.stream().filter(o -> {
        System.out.println(o);
        return o > 10;
    }).limit(2).sorted();
    
    中间操作和终端操作

    相关文章

      网友评论

          本文标题:Java 8:流操作(Stream)的三要素:数据源、中间操作和

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