您当前的位置: 首页 > 

小志的博客

暂无认证

  • 0浏览

    0关注

    1217博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

jdk1.8新特性——Stream(流)的终止操作基本语法

小志的博客 发布时间:2021-08-28 22:10:53 ,浏览量:0

目录
    • 一、Stream(流)的理解
    • 二、Stream(流)是什么
    • 三、Stream(流)的注意事项
    • 四、Stream API 的操作步骤
      • 1、创建 Stream
      • 2、中间操作 Stream
      • 3、终止Stream
      • 4、Stream API 的操作步骤图解
    • 五、Stream(流)的终止操作语法
      • 1、查找与匹配
      • 2、归约
      • 3、收集

一、Stream(流)的理解
  • Stream是Java8中处理集合的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行非常复杂的查找、过滤和映射数据等操作。
  • 使用Stream API对集合数据进行操作,类似于使用SQL执行的数据库查询。
  • 使用Stream API 来并行执行操作。
  • Stream API提供了一种高效且易于使用的处理数据的方式。
二、Stream(流)是什么
  • Stream(流)是数据渠道,用于操作数据源(集合、数组等)所生成的元素序列。
  • 集合关注的是数据,流关注的是计算。
三、Stream(流)的注意事项
  • Stream自己不会存储元素。
  • Stream不会改变源对象。相反,他们会返回一个持有结果的新Stream。
  • Stream操作时延迟执行。这意味着他们会等到需要结果的时候才执行。
四、Stream API 的操作步骤 1、创建 Stream
  • 一个数据源(如:集合、数组),获取一个流。
2、中间操作 Stream
  • 一个中间操作链,对数据源的数据进行处理。
  • 多个中间操作可以连接起来形成一个流水线,除非流水线上触发终止操作,否则中间操作不会执行任何的处理,而在终止操作时一次性全部处理,称为“惰性求值”。
3、终止Stream
  • 一个终止操作,执行中间操作链,并产生结果。
  • 终端操作会从流的流水线生成结果。其结果可以是任何不是流的值,例如:List、Integer,甚至是 void 。
4、Stream API 的操作步骤图解

在这里插入图片描述

五、Stream(流)的终止操作语法 1、查找与匹配 方法描述allMatch(Predicate p)检查是否匹配所有元素anyMatch(Predicate p)检查是否至少匹配一个元素noneMatch(Predicate p)检查是否没有匹配所有元素findFirst()返回第一个元素findAny()返回当前流中的任意元素count()返回流中元素总数max(Comparator c)返回流中最大值min(Comparator c)返回流中最小值forEach(Consumer c)内部迭代(使用 Collection 接口需要用户去做迭代,称为外部迭代。相反,Stream API 使用内部迭代——它帮你把迭代做了) 2、归约 方法描述reduce(T iden, BinaryOperator b)可以将流中元素反复结合起来,得到一个值。返回 Treduce(BinaryOperator b)可以将流中元素反复结合起来,得到一个值。返回 Optional< T > 3、收集 方法描述collect(Collector c)将流转换为其他形式。接收一个 Collector接口的实现,用于给Stream中元素做汇总的方法
  • collect方法中的参数Collector 接口中方法的实现决定了如何对流执行收集操作(如收集到 List、Set、Map)。但是 Collectors 实用类提供了很多静态方法,可以方便地创建常见收集器实例,具体方法与实例如下表:
方法返回类型作用toListList< T>把流中元素收集到List toSetSet< T>把流中元素收集到Set toCollectionCollection< T>把流中元素收集到创建的集合countingLong计算流中元素的个数summingIntInteger对流中元素的整数属性求和 averagingIntDouble计算流中元素Integer属性的平均值 summarizingIntIntSummaryStatistics收集流中Integer属性的统计值。如:平均值joiningString连接流中每个字符串maxByOptional根据比较器选择最大值minByOptional根据比较器选择最小值reducing归约产生的类型从一个作为累加器的初始值开始,利用BinaryOperator与流中元素逐个结合,从而归约成单个值collectingAndThen转换函数返回的类型包裹另一个收集器,对其结果转换函数groupingByMap>根据某属性值对流分组,属性为K,结果为VpartitioningByMap>根据true或false进行分区
关注
打赏
1661269038
查看更多评论
立即登录/注册

微信扫码登录

0.0432s