jdk1.8新特性——Stream(流)的终止操作基本语法
Posted 小志的博客
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jdk1.8新特性——Stream(流)的终止操作基本语法相关的知识,希望对你有一定的参考价值。
目录
一、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) | 可以将流中元素反复结合起来,得到一个值。返回 T |
reduce(BinaryOperator b) | 可以将流中元素反复结合起来,得到一个值。返回 Optional< T > |
3、收集
方法 | 描述 |
---|---|
collect(Collector c) | 将流转换为其他形式。接收一个 Collector接口的实现,用于给Stream中元素做汇总的方法 |
- collect方法中的参数Collector 接口中方法的实现决定了如何对流执行收集操作(如收集到 List、Set、Map)。但是 Collectors 实用类提供了很多静态方法,可以方便地创建常见收集器实例,具体方法与实例如下表:
方法 | 返回类型 | 作用 |
---|---|---|
toList | List< T> | 把流中元素收集到List |
toSet | Set< T> | 把流中元素收集到Set |
toCollection | Collection< T> | 把流中元素收集到创建的集合 |
counting | Long | 计算流中元素的个数 |
summingInt | Integer | 对流中元素的整数属性求和 |
averagingInt | Double | 计算流中元素Integer属性的平均值 |
summarizingInt | IntSummaryStatistics | 收集流中Integer属性的统计值。如:平均值 |
joining | String | 连接流中每个字符串 |
maxBy | Optional | 根据比较器选择最大值 |
minBy | Optional | 根据比较器选择最小值 |
reducing | 归约产生的类型 | 从一个作为累加器的初始值开始,利用BinaryOperator与流中元素逐个结合,从而归约成单个值 |
collectingAndThen | 转换函数返回的类型 | 包裹另一个收集器,对其结果转换函数 |
groupingBy | Map<K, List< T>> | 根据某属性值对流分组,属性为K,结果为V |
partitioningBy | Map<Boolean, List< T>> | 根据true或false进行分区 |
以上是关于jdk1.8新特性——Stream(流)的终止操作基本语法的主要内容,如果未能解决你的问题,请参考以下文章
jdk1.8新特性——Stream(流)的终止操作(归约的示例演示)
jdk1.8新特性——Stream(流)的终止操作(查找与匹配的示例演示)