news 2026/5/12 3:05:09

Stream流式编程 中间操作和终端操作介绍

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Stream流式编程 中间操作和终端操作介绍

一、先立心智模型:Stream 到底是什么?

Stream 不是集合,不存数据,不改数据。

它是:

对数据源的一次性、惰性的、函数式“处理流程描述”

三点必须刻在脑子里:

  1. 惰性执行:中间操作不执行,直到终端操作出现

  2. 流水线模型:元素一个一个穿过全部操作

  3. 一次性消费:终端操作后流关闭

stream.中间操作1().中间操作2().终端操作();

二、Stream 操作的两大阵营

分类作用是否立即执行是否返回 Stream
中间操作描述“怎么处理”❌ 否✅ 是
终端操作触发执行、拿结果✅ 是❌ 否

三、中间操作(Intermediate Operations)

核心作用一句话

中间操作负责“塑形”和“筛选”,不产出结果,只返回新 Stream。


1️⃣ filter:筛选(留下什么)

stream.filter(predicate)

作用:

只让predicate 返回 true 的元素继续往下走

users.stream().filter(u->u.getAge()>=18)

🧠 心法:
永远写“我要什么”,不是“我要丢掉什么”


2️⃣ map:映射(变形)

stream.map(mapper)

作用:

T → R

users.stream().map(User::getName)

注意:

  • 会发生装箱/拆箱

  • 结果是Stream<R>


3️⃣ mapToInt / mapToLong / mapToDouble:数值专用映射

stream.mapToInt(User::getAge)

作用:

转为基本类型流,用于数值计算

好处:

  • 性能更好

  • 可以直接sum / average / max


4️⃣ flatMap:扁平化(降维打击)

stream.flatMap(mapper)

作用:

典型场景:

  • 一对多

  • 集合嵌套

  • SQL 中的 join 思维


5️⃣ distinct:去重

stream.distinct()

基于:

  • equals

  • hashCode

⚠️ 对象必须正确实现这两个方法。


6️⃣ sorted:排序

stream.sorted()stream.sorted(comparator).sorted(Comparator.comparing(User::getAge))

7️⃣ limit / skip:截断与跳过(短路)

.limit(10).skip(5)

作用:

  • limit:最多取 N 个

  • skip:跳过前 N 个

🔥 这是短路操作,会提前终止流水线。


8️⃣ peek:窥视(调试用)

.peek(System.out::println)

⚠️ 不要在peek里写业务逻辑。


四、终端操作(Terminal Operations)

核心作用一句话

终端操作负责“触发执行”和“产出结果”,一旦调用,Stream 关闭。


1️⃣ forEach:消费流

stream.forEach(action)

特点:

  • 无返回值

  • 只做“消费”

⚠️ 不推荐在里面修改外部变量。


2️⃣ collect:收集结果(最重要🔥)

stream.collect(collector)

作用:

把流中的元素收集成你想要的结构

常见:

.toList().toSet().toMap().groupingBy().joining()

3️⃣ reduce:归约(底层思想)

stream.reduce(identity, accumulator)

int sum = nums.stream().reduce(0, Integer::sum);

collect 的思想基础。


4️⃣ count:计数

stream.count()


5️⃣ max / min:极值

stream.max(comparator)

返回:

Optional<T>


6️⃣ findFirst / findAny:查找(短路)

.findFirst() .findAny()

返回 Optional。


7️⃣ anyMatch / allMatch / noneMatch:匹配判断(短路)

.anyMatch() .allMatch() .noneMatch()


五、执行顺序真相(重要)

stream.filter().limit().map().forEach();

❌ 错误理解:

filter 执行完,再执行 limit

✅ 正确理解:

一个元素 → filter → limit → map → forEach

流水线 + 惰性 + 短路。


六、一张表吃透(面试版)

操作类型代表方法特点
筛选filter留下 true
转换map / flatMap变形
排序sorted有状态
截断limit短路
收集collect最常用
判断anyMatch短路
查找findFirst短路
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/9 0:40:15

计算机深度学习毕设实战-基于python深度学习的印刷体数字和字母识别基于机器学习的印刷体数字和字母识别

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/5/9 13:49:43

Day60 PythonStudy

浙大疏锦行 import torch import torch.nn as nn import torch.nn.functional as F import torchvision import torchvision.transforms as transforms from torch.utils.data import DataLoader import matplotlib.pyplot as plt import numpy as np# 设置随机种子保证可重复…

作者头像 李华
网站建设 2026/4/30 15:35:42

Mysql 驱动程序

一、MySQL 驱动程序的概念 驱动程序的主要功能包括&#xff1a; 建立连接&#xff1a;驱动程序负责处理应用程序和 MySQL 数据库之间的网络连接。执行 SQL 语句&#xff1a;驱动程序将应用程序中的 SQL 语句发送到数据库服务器&#xff0c;并接收服务器的响应。处理结果集&am…

作者头像 李华
网站建设 2026/5/11 9:00:56

mysql 迁移达梦数据库出现的 sql 语法问题 以及迁移方案

迁移方案&#xff1a; 1.下载官方DM8开发版 产品下载-达梦数据 2.会下载到win系统下的左下角的开始 1.1.2 创建工程 右击空白处&#xff0c;新建 1.1.3 新建迁移 1.1.3.1 选择迁移方式 MySql迁移DM 1.1.3.2 配置数据源 输入你的mysql配置后&#xff0c;刷新&#xff0c;选择…

作者头像 李华