java 8 Stream中操作类型和peek的使用
java 8 stream作为流式操作有两种操作类型,中间操作和终止操作。这两种有什么区别呢?
我们看一个peek的例子:
Stream<String> stream = Stream.of("one", "two", "three","four"); stream.peek(System.out::println);
上面的例子中,我们的本意是打印出Stream的值,但实际上没有任何输出。
为什么呢?
一个java 8的stream是由三部分组成的。数据源,零个或一个或多个中间操作,一个或零个终止操作。
中间操作是对数据的加工,注意,中间操作是lazy操作,并不会立马启动,需要等待终止操作才会执行。
终止操作是stream的启动操作,只有加上终止操作,stream才会真正的开始执行。
所以,问题解决了,peek是一个中间操作,所以上面的例子没有任何输出。
我们看下peek的文档说明:peek主要被用在debug用途。
我们看下debug用途的使用:
Stream.of("one", "two", "three","four").filter(e -> e.length() > 3) .peek(e -> System.out.println("Filtered value: " + e)) .map(String::toUpperCase) .peek(e -> System.out.println("Mapped value: " + e)) .collect(Collectors.toList());
上面的例子输出:
Filtered value: three Mapped value: THREE Filtered value: four Mapped value: FOUR
上面的例子我们输出了stream的中间值,方便我们的调试。
为什么只作为debug使用呢?我们再看一个例子:
Stream.of("one", "two", "three","four").peek(u -> u.toUpperCase()) .forEach(System.out::println);
上面的例子我们使用peek将element转换成为upper case。然后输出:
one two three four
可以看到stream中的元素并没有被转换成大写格式,所以peek只作为debug使用。
再看一个map的对比:
Stream.of("one", "two", "three","four").map(u -> u.toUpperCase()) .forEach(System.out::println);
输出:
ONE TWO THREE FOUR
可以看到map是真正的对元素进行了转换。
我们在本文中讲解了stream的两个操作类型,并总结了peek的使用。希望大家能够掌握。
本文的例子 https://github.com/ddean2009/learn-java-streams/tree/master/stream-peek