news 2026/2/26 19:42:37

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/2/19 2:44:31

ArcGIS土地利用现状图制作全流程

将之前《ArcGIS Pro从0到1制作广东省土地利用现状图》直播回重新录制一遍给大家学习。详见下方视频教学 主要涉及的内容包括&#xff1a;ArcGIS土地利用现状图全流程教学&#xff08;从零数据下载、镶嵌、裁剪、属性表连接整理、面积区域汇总计算、地图全流程制作&#xff09; …

作者头像 李华
网站建设 2026/2/14 2:44:08

题解:AT_iroha2019_day3_f 闇のカードゲーム

AT_iroha2019_day3_f 闇のカードゲーム 题目描述 桌上整齐地摆放着 NNN 张卡片&#xff08;NNN 为奇数&#xff09;&#xff0c;每张卡片上有一个正整数。卡片按整数从小到大排列&#xff0c;位于第 iii 张卡片上的整数为 aia_iai​。不同的卡片上不会有相同的整数。 すぬけ君和…

作者头像 李华
网站建设 2026/2/20 5:52:47

MySql-9.1.0安装详细教程(保姆级)

目录 MySQL介绍&#xff1a; 一、下载 Mysql 安装文件 二、Mysql 安装教程 1.下载完成后进入解压&#xff0c;注意不要放在一个非中文路径下的文件夹下面否则后面会报错。我在此处解压放在了D盘MySQL目录下。 2.解压后的文件应该没有.ini文件。因此&#xff0c;需要创建in…

作者头像 李华