Stream流 设计出来是为了什么?
过滤数据,把原始数据变成自己想要的数据。比如找出某个集合中满足某个条件的数据,形成1个新的数据。
它是怎么实现的呢?
1:先把List 变成 stream 流对象。
2:中间操作:过滤、去重、分页(可以有很多次,没有返回值)
3:终端操作:处理、收集收据。(你可以理解为交卷)
代码演示:
先把List 变成 stream 流对象。
过滤、去重、分页(中间操作,可以有很多次,没有返回值)
常见的Stream流终端操作包括:
forEach
:对流中的每个元素执行指定的操作。toArray
:将流中的元素转换为数组。reduce
:通过指定的累积函数将流中的元素归约为单个值。collect
:将流中的元素收集到一个集合或映射中。min
和max
:找到流中的最小值或最大值。count
:统计流中的元素个数。anyMatch
、allMatch
和noneMatch
:检查流中的元素是否满足指定条件。findFirst
和findAny
:查找流中的第一个元素或任意一个元素。forEachOrdered
:对有序流中的每个元素执行指定的操作。iterator
:获取流的迭代器。
终端操作,需要1个结果。就需要返回 distinct.count()。
这就是流怎么操作集合的思想。