1、stream不存储数据,而是按照特定的规则对数据进行计算,一般会输出结果;
2、stream不会改变数据源,通常情况下会产生一个新的集合;
3、stream具有延迟执行特性,只有调用终端操作时,中间操作才会执行;
4、对stream操作分为终端操作和中间操作
终端操作:会消费流,这种操作会产生一个结果的,如果一个流被消费过了,那它就不能被重用的。
中间操作:中间操作会产生另一个流。因此中间操作可以用来创建执行一系列动作的管道。一个特别需要注意的点是:中间操作不是立即发生的。相反,当在中间操作创建的新流上执行完终端操作后,中间操作指定的操作才会发生。所以中间操作是延迟发生的,中间操作的延迟行为主要是让流API能够更加高效地执行。
5、stream不可复用,对一个已经进行过终端操作的流再次调用,会抛出异常。
Stream的操作可以分为两大类:中间操作、终结操作
中间操作可分为:
无状态(Stateless)操作:指元素的处理不受之前元素的影响
有状态(Stateful)操作:指该操作只有拿到所有元素之后才能继续下去
终结操作可分为:
短路(Short-circuiting)操作:指遇到某些符合条件的元素就可以得到最终结果
非短路(Unshort-circuiting)操作:指必须处理完所有元素才能得到最终结果
java.util.Collection.stream() 方法用集合创建流- List<String> list = Arrays.asList("hello","world","stream");
- //创建顺序流
- Stream<String> stream = list.stream();
- //创建并行流
- Stream<String> parallelStream = list.parallelStream();
java.util.Arrays.stream(T[] array)方法用数组创建流- String[] array = {"h", "e", "l", "l", "o"};
- Stream<String> arrayStream = Arrays.stream(array);
Stream的静态方法:of()、iterate()、generate()- Stream<Integer> stream1 = Stream.of(1, 2, 3, 4, 5, 6);
-
- Stream<Integer> stream2 = Stream.iterate(0, (x) -> x + 2).limit(3);
- stream2.forEach(System.out::println);
-
- Stream<Double> stream3 = Stream.generate(Math::random).limit(3);
- stream3.forEach(System.out::println)
-
-
- //输出结果如下:
-
- 0
- 2
- 4
- 0.9620319103852426
- 0.8303672905658537
- 0.09203215202737569