Java stream quot;forEachquot; but not consuming stream(Java 流“forEach但不消耗流)
问题描述
有时在处理流的步骤之间对流中的每个元素执行某些操作"(例如打印)会很方便,例如用于调试.
Sometimes it would be handy do "something" (e.g. print) with every element in a stream in between steps of processing the stream, e.g. for debugging.
一个简单的例子可能看起来像这样,不幸的是这不起作用,因为 forEach 消耗流:
A simple example could look like this, unfortunately this does not work as forEach consumes the stream:
List<String> list = new ArrayList<>();
list.add("one");
list.add("two");
list.add("three");
list.add("four");
List<String> filteredList =
list.stream()
.filter(s -> s.startsWith("t"))
.forEach(System.out::println)
.collect(Collectors.toList());
如何做到这一点?
推荐答案
您正在寻找 peek 操作:
You are looking for the peek operation:
此方法的存在主要是为了支持调试,您希望在元素流过管道中的某个点时查看它们
This method exists mainly to support debugging, where you want to see the elements as they flow past a certain point in a pipeline
此方法将在 Stream 管道的所有元素被消耗时执行给定的操作.因此,它允许获取 peek 元素.
This method will execute the given action on all elements of the Stream pipeline as they are consumed. As such, it allows to take a peek of the elements.
List<String> filteredList =
list.stream()
.filter(s -> s.startsWith("t"))
.peek(System.out::println)
.collect(Collectors.toList());
这篇关于Java 流“forEach"但不消耗流的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Java 流“forEach"但不消耗流
基础教程推荐
- Spring AOP错误无法懒惰地为此建议构建thisJoinPoin 2022-09-13
- 使用堆栈算法进行括号/括号匹配 2022-01-01
- 存储 20 位数字的数据类型 2022-01-01
- 修改 void 函数的输入参数,然后读取 2022-01-01
- 如何对 Java Hashmap 中的值求和 2022-01-01
- RabbitMQ:消息保持“未确认"; 2022-01-01
- 问题http://apache.org/xml/features/xinclude测试日志4j 2 2022-01-01
- 无法复制:“比较方法违反了它的一般约定!" 2022-01-01
- Struts2 URL 无法访问 2022-01-01
- REST Web 服务返回 415 - 不支持的媒体类型 2022-01-01
