java8 stream peak
时间: 2024-04-12 10:26:03 浏览: 118
Java 8引入了Stream API,其中的peak操作是Stream中的一个中间操作,它允许我们在流的处理过程中查看流中的元素,而不会改变流的内容。
peak操作的语法如下:
```
Stream<T> peak(Consumer<? super T> action)
```
它接受一个Consumer函数作为参数,该函数会对流中的每个元素进行操作。在每个元素被消费之前,我们可以在peak操作中执行一些自定义的逻辑,例如打印元素的值、记录日志等。
下面是一个示例代码,展示了如何使用peak操作:
```java
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
numbers.stream()
.peek(System.out::println) // 打印每个元素的值
.map(n -> n * 2) // 对每个元素进行乘以2的操作
.forEach(System.out::println); // 打印操作后的结果
```
在上述示例中,我们首先使用peek操作打印了每个元素的值,然后使用map操作对每个元素进行乘以2的操作,最后使用forEach操作打印操作后的结果。
阅读全文