Java Stream API中peek操作

1、简介

在Java的Stream API中,peek()是一个中间操作,它允许你查看流中的元素,但是并不会对它们进行修改或影响流的后续处理。换句话说,peek()方法提供了一个"窥视"流中元素的机会,但并不改变流本身或其元素的顺序。

peek()方法接受一个Consumer<? super T>类型的参数,该参数是一个函数接口,它定义了一个accept(T t)方法,用于处理流中的每一个元素。

2、示例

java 复制代码
import java.util.Arrays;  
import java.util.List;  
import java.util.stream.Collectors;  
  
public class StreamPeekExample {  
    public static void main(String[] args) {  
        List<String> list = Arrays.asList("a", "b", "c", "d", "e");  
  
        // 使用peek()查看流中的每个元素,但不影响流的最终操作  
        List<String> result = list.stream()  
            .peek(element -> System.out.println("Processing: " + element))  
            .filter(s -> s.compareTo("c") > 0) // 过滤掉小于"c"的元素  
            .collect(Collectors.toList()); // 收集结果到新的列表中  
  
        // 输出过滤后的结果  
        System.out.println("Filtered list: " + result);  
    }  
}

虽然peek()在某些情况下可能很有用(例如调试或记录),但它并不应该被用作流处理的主要部分,因为它并不改变流本身或其中的元素。如果你需要在流处理过程中修改元素或改变流的状态,应该使用其他适当的操作,如map()flatMap()filter()等。

相关推荐
oak隔壁找我7 小时前
JVM常用调优参数
java·后端
蝎子莱莱爱打怪12 小时前
OpenClaw 从零配置指南:接入飞书 + 常用命令 + 原理图解
java·后端·ai编程
狼爷13 小时前
Go 没有 override?别硬套继承!用接口+嵌入,写更清爽的“覆盖”逻辑
java·go
小兔崽子去哪了15 小时前
Java 自动化部署
java·后端
ma_king16 小时前
入门 java 和 数据库
java·数据库·后端
后端AI实验室16 小时前
我用Cursor开发了3个月,整理出这套提效4倍的工作流
java·ai
码路飞20 小时前
GPT-5.3 Instant 终于学会好好说话了,顺手对比了下同天发布的 Gemini 3.1 Flash-Lite
java·javascript
SimonKing20 小时前
OpenCode AI编程助手如何添加Skills,优化项目!
java·后端·程序员
Seven971 天前
剑指offer-80、⼆叉树中和为某⼀值的路径(二)
java
怒放吧德德1 天前
Netty 4.2 入门指南:从概念到第一个程序
java·后端·netty