行业资讯 2025年08月6日
0 收藏 0 点赞 385 浏览 1307 个字
摘要 :

文章目录 1.Stream peek()方法 1.1 用途 1.2 方法语法 1.3 描述 2.Stream peek()示例 2.1 使用没有终端操作的peek() 2.2 使用带有终端操作的peek() 3.结论 Java St……




  • 1.Stream peek()方法
    • 1.1 用途
    • 1.2 方法语法
    • 1.3 描述
  • 2.Stream peek()示例
    • 2.1 使用没有终端操作的peek()
    • 2.2 使用带有终端操作的peek()
  • 3.结论

Java Stream的peek()方法返回一个新的Stream,它包含来自原始Stream的所有元素,这些元素在应用给定的Consumer操作后产生。

请注意,peek()方法是一种中间Stream操作,因此要处理通过peek()方法产生的Stream元素,我们必须使用终端操作。如果不使用任何终端操作而只使用Stream.peek(),则不会有任何效果。

1.Stream peek()方法

1.1 用途

根据Java文档,当我们想要看到在流处理管道中流动的具体元素时,peek()方法可以有效帮助我们实现相关调试。

我们可以在每个中间操作之后调用peek()方法,以查看中间操作对Stream元素的影响。

Stream<T> stream = createStream();
stream.operationOne()
    .peek()
    .operationTwo()
    .peek()
    .terminalOperation();

1.2 方法语法

peek()返回一个新的Stream,该Stream由来自原始Stream的元素组成。

这里的action是对元素进行消费的中间操作,它对从Stream中消费的元素执行非干扰操作,并将执行操作后的结果元素放入新的Stream中。

SyntaxStream<T> peek(Consumer<? super T> action)

1.3 描述

  • Stream peek()方法是中间操作。
  • 它返回一个由当前流的元素组成的Stream。
  • 它还对每个元素执行提供的Consumer操作。
  • 对于并行流管道,该操作可能在任何时间、任何线程中由上游操作提供元素时被调用。
  • 如果操作修改共享状态,则它本身负责提供所需的同步。
  • peek()主要用于支持调试,我们希望在元素流经管道的某个点时看到它们。

2.Stream peek()示例

2.1 使用没有终端操作的peek()

如上所述,没有终端操作的Stream.peek()没有任何效果。

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
list.stream()
  .peek( System.out::println );   //啥输出也没有

2.2 使用带有终端操作的peek()

Java程序使用peek() API来调试Stream操作,并记录在处理过程中Stream的元素。

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> newList = list.stream()
      .peek(System.out::println)
      .collect(Collectors.toList());
System.out.println(newList);

输出:

1
2
3
4
5
[1, 2, 3, 4, 5]

3.结论

Stream.peek()方法可以帮助我们可视化流操作的行为,并理解复杂中间流操作的含义和交互。尽管可以修改流中元素的内部状态,但强烈建议不要这样做。

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/9562.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

988
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

465
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

348
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

456
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

517
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

832
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号