一.什么是Stream
Stream流是Java 8中的一个新特性,它提供了一种处理集合和数组的方式。Stream流可以让我们以一种更加简洁、高效、可读性更强的方式来处理数据。Stream流可以用于过滤、映射、排序、聚合等操作,它可以让我们避免使用循环和条件语句来处理数据,从而让代码更加简洁易懂。
它允许你以声明式的方式处理数据集合,可以把它看作是遍历数据集的高级迭代器。此外与 stream 与 lambada 表达示结合后编码效率与大大提高,并且可读性更强。要澄清的是 java8 中的 stream 与 InputStream 和 OutputStream 是完全不同的概念。
二.获取流
1.使用 Collection 接口下的 stream()
List<String> list = new ArrayList<>();
Stream<String> stream = list.stream();
2.使用 Arrays 中的 stream() 方法,将数组转成流
Integer[] nums = new Integer[10];
Stream<Integer> stream = Arrays.stream(nums);
3.使用 Stream 中的静态方法:of()
Stream<Integer> stream = Stream.of(1,2,3,4,5,6);
三.操作流
流操作可以分为两类:
中间操作
和
终端操作
。
可以简化为:
数据源 => 中间操作 => 终端操作 => 结果
1.中间操作
filter:过滤流中的某些元素sorted(): 自然排序,流中元素需实现 Comparable 接口distinct: 去除重复元素limit(n): 获取 n 个元素skip(n): 跳过 n 元素,配合 limit(n)可实现分页map(): 将其映射成一个新的元素
1.filter:过滤流中的某些元素
![](https://i-blog.csdnimg.cn/direct/30356e01ea2a45229db8a935a1948d2e.png)
2.sorted(): 自然排序,流中元素需实现 Comparable 接口
![](https://i-blog.csdnimg.cn/direct/2a201fc25d824e74b34f2c20161bf8b8.png)
3.distinct: 去除重复元素
![](https://i-blog.csdnimg.cn/direct/ce41930457a14d73b97adfdbcd47f4a9.png)
4.limit(n): 获取 n 个元素
![](https://i-blog.csdnimg.cn/direct/b35a1646df984fbfbc6f2590dc74b3fe.png)
5.skip(n): 跳过 n 元素,配合 limit(n)可实现分页
![](https://i-blog.csdnimg.cn/direct/00ce732b68f348bfa43a21d304a39420.png)
6.map(): 将其映射成一个新的元素
![](https://i-blog.csdnimg.cn/direct/102f2d94038549e98d6c6d18992c8787.png)
2.终端操作
forEach: 遍历流中的元素toArray:将流中的元素倒入一个数组Min:返回流中元素最小值Max:返回流中元素最大值count:返回流中元素的总个数Reduce:所有元素求和anyMatch:接收一个 Predicate 函数,只要流中有一个元素满足条件则返 回 true,否则返回 falseallMatch:接收一个 Predicate 函数,当流中每个元素都符合条件时才返 回 true,否则返回 falsefindFirst:返回流中第一个元素collect:将流中的元素倒入一个集合,Collection 或 Map
1.forEach: 遍历流中的元素
(看上面中间操作哈)
2.toArray:将流中的元素倒入一个数组
![](https://i-blog.csdnimg.cn/direct/dd0cc1d5950148c3afadf7b47abae968.png)
3.Min:返回流中元素最小值
![](https://i-blog.csdnimg.cn/direct/04b86b88d519455799e8387541f0ff8c.png)
4.Max:返回流中元素最大值
![](https://i-blog.csdnimg.cn/direct/6c1975f82a5d4cc8a8f619912ea355ae.png)
5.count:返回流中元素的总个数
![](https://i-blog.csdnimg.cn/direct/f9058b682c9a44c6b6d48fdd0793e297.png)
6.Reduce:所有元素求和
![](https://i-blog.csdnimg.cn/direct/b038bcbefd4a4955b83381f8757019ae.png)
7.anyMatch:接收一个 Predicate 函数,只要流中有一个元素满足条件则返 回 true,否则返回 false
![](https://i-blog.csdnimg.cn/direct/1cb968d26b68451fb7c68983c6dcd1fa.png)
![](https://i-blog.csdnimg.cn/direct/d781be38a7814564aa20524290bfe27f.png)
8.allMatch:接收一个 Predicate 函数,当流中每个元素都符合条件时才返 回 true,否则返回 false
![](https://i-blog.csdnimg.cn/direct/e2b4612e931943fdbdad7441922c4ce7.png)
![](https://i-blog.csdnimg.cn/direct/f323d69307e94c7c8182f56bcf486c7a.png)
9.findFirst:返回流中第一个元素
![](https://i-blog.csdnimg.cn/direct/780a0af583f74a49806355b1cda17574.png)
10.collect:将流中的元素倒入一个集合,Collection 或 Map