当前位置: 首页 > news >正文

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短路
http://www.jsqmd.com/news/217013/

相关文章:

  • 【苹果分级】基于matlab GUI机器视觉苹果质量检测及总分级系统【含Matlab源码 14878期】
  • 【课程设计/毕业设计】基于深度学习的印刷体数字和字母识别基于python深度学习的印刷体数字和字母识别
  • 深度学习计算机毕设之机器学习基于CNN深度学习的遥感图片识别沙漠湖泊和森林
  • ArcGIS土地利用现状图制作全流程
  • Merge3D 三维引擎中 GeoJSON 数据加载的整体设计
  • K8S安装指南与核心操作命令汇总
  • 企业知识管理新范式:用ChatWiki+大模型实现“一问即答“[必学收藏]
  • 15_嵌入式C与控制理论入门:控制算法的定点数优化与精度平衡
  • 新下证美国外观专利:42款亚马逊侵权高危新品,跨境卖家立即自查!
  • 【毕业设计】python基于CNN深度学习的遥感图片识别沙漠湖泊和森林
  • Mysql 驱动程序
  • 【值得收藏】Agent-Graph:构建强大多智能体系统的完整教程
  • ArcGIS汉化不成功的解决方案
  • 港美主流期货 API 接入全指南:TradingView 看盘策略
  • 【毕业设计】基于python深度学习的印刷体数字和字母识别基于python的印刷体数字和字母识别
  • 一部手机不够玩?鸿蒙如何把多设备变成一个游戏系统(实战解析)
  • .NET开发必备:Redis、IoC、AutoMapper实战指南
  • 大型C项目的头文件管理:3招解决“重复包含”与“依赖混乱”
  • MemR3:给大模型记忆系统装一个“会思考的小脑“,准确率提升5-9%
  • 用 Wireshark 嗅探 ESP32 通信数据,教你看懂“WiFi 的语言”
  • 题解:AT_iroha2019_day3_f 闇のカードゲーム
  • Day60 PythonStudy
  • 【机械臂】基于Sawyer机械臂的多目标 RRT 路径规划 + 轨迹跟踪控制+ 数据生成附matlab代码
  • AI产品经理VS普通产品经理:AI思维才是核心竞争力,程序员必学技能
  • 【Hadoop+Spark+python毕设】近8年软科中国大学排名数据可视化分析系统、计算机毕业设计、包括数据爬取、数据分析、数据可视化、实战教学
  • MySQL--》深入理解视图、存储过程与触发器的强大功能
  • 【法学专业论文写作模版】未成年人犯罪低龄化问题及对策研究
  • 计算机网络必看:信道的极限容量,408真题常考!
  • AI大模型开发学习指南:助你实现90%就业率和年薪72w+_AI爆了!最高年薪72w!
  • 手机变+Linux+控制台?JuiceSSH+++cpolar远程连接让运维随时随地搞定