Java中的Stream API:从入门到实战
引言
在现代Java开发中,Stream API 是处理集合数据的强大工具。它不仅让代码更加简洁易读,还能通过并行处理提升性能。本文将带你从基础概念入手,逐步深入Stream API的使用,并通过实战案例展示其强大功能。
1. 什么是Stream API?
Stream API 是Java 8引入的一个新特性,用于处理集合数据。它允许你以声明式的方式对数据进行操作,比如过滤、映射、排序等。Stream API的核心思想是将数据操作分为中间操作和终端操作。
- 中间操作:如
filter()、map()、sorted(),它们返回一个新的Stream,可以链式调用。 - 终端操作:如
collect()、forEach()、reduce(),它们触发Stream的处理并返回结果。
2. Stream API的核心操作
2.1 创建Stream
Stream可以通过多种方式创建:
// 从集合创建
List<String> list = Arrays.asList("Java", "Python", "C++");
Stream<String> stream = list.stream();// 从数组创建
Stream<String> arrayStream = Arrays.stream(new String[]{"A", "B", "C"});// 使用Stream.of()
Stream<Integer> numberStream = Stream.of(1, 2, 3, 4);
2.2 中间操作
- filter():过滤元素
List<String> languages = Arrays.asList("Java", "Python", "C++", "JavaScript");
List<String> filtered = languages.stream().filter(lang -> lang.startsWith("J")).collect(Collectors.toList());
// 结果: ["Java", "JavaScript"]
- map():转换元素
List<String> languages = Arrays.asList("Java", "Python", "C++");
List<Integer> lengths = languages.stream().map(String::length).collect(Collectors.toList());
// 结果: [4, 6, 3]
- sorted():排序
List<String> sortedLanguages = languages.stream().sorted().collect(Collectors.toList());
// 结果: ["C++", "Java", "JavaScript", "Python"]
2.3 终端操作
- collect():将Stream转换为集合
List<String> result = stream.collect(Collectors.toList());
- forEach():遍历元素
languages.stream().forEach(System.out::println);
- reduce():归约操作
Optional<String> combined = languages.stream().reduce((s1, s2) -> s1 + ", " + s2);
// 结果: "Java, Python, C++"
3. 并行Stream
Stream API 支持并行处理,只需将 stream() 替换为 parallelStream() 即可:
List<String> languages = Arrays.asList("Java", "Python", "C++", "JavaScript");
List<String> result = languages.parallelStream().filter(lang -> lang.length() > 3).collect(Collectors.toList());
4. 实战案例:统计文本中的单词频率
假设我们有一段文本,需要统计每个单词出现的频率:
String text = "Java is a programming language Java is widely used";
Map<String, Long> wordCounts = Arrays.stream(text.split(" ")).collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));
// 结果: {Java=2, is=2, a=1, programming=1, language=1, widely=1, used=1}
5. 注意事项
- Stream是一次性的:一旦被消费,就不能重复使用。
- 避免副作用:Stream操作应尽量保持无状态,避免修改外部变量。
- 性能权衡:并行Stream并不总是更快,需根据数据量和操作复杂度评估。
6. 总结
Stream API 是Java中处理集合数据的利器,它让代码更加简洁、易读且高效。通过本文的学习,你应该已经掌握了Stream的基本用法,并能够在实际项目中灵活运用。希望这篇博客对你有所帮助!
推荐阅读文章
-
由 Spring 静态注入引发的一个线上T0级别事故(真的以后得避坑)
-
如何理解 HTTP 是无状态的,以及它与 Cookie 和 Session 之间的联系
-
HTTP、HTTPS、Cookie 和 Session 之间的关系
-
什么是 Cookie?简单介绍与使用方法
-
什么是 Session?如何应用?
-
使用 Spring 框架构建 MVC 应用程序:初学者教程
-
有缺陷的 Java 代码:Java 开发人员最常犯的 10 大错误
-
如何理解应用 Java 多线程与并发编程?
-
把握Java泛型的艺术:协变、逆变与不可变性一网打尽
-
Java Spring 中常用的 @PostConstruct 注解使用总结
-
如何理解线程安全这个概念?
-
理解 Java 桥接方法
-
Spring 整合嵌入式 Tomcat 容器
-
Tomcat 如何加载 SpringMVC 组件
-
“在什么情况下类需要实现 Serializable,什么情况下又不需要(一)?”
-
“避免序列化灾难:掌握实现 Serializable 的真相!(二)”
-
如何自定义一个自己的 Spring Boot Starter 组件(从入门到实践)
-
解密 Redis:如何通过 IO 多路复用征服高并发挑战!
-
线程 vs 虚拟线程:深入理解及区别
-
深度解读 JDK 8、JDK 11、JDK 17 和 JDK 21 的区别
-
10大程序员提升代码优雅度的必杀技,瞬间让你成为团队宠儿!
-
“打破重复代码的魔咒:使用 Function 接口在 Java 8 中实现优雅重构!”
-
Java 中消除 If-else 技巧总结
-
线程池的核心参数配置(仅供参考)
-
【人工智能】聊聊Transformer,深度学习的一股清流(13)
-
Java 枚举的几个常用技巧,你可以试着用用
-
由 Spring 静态注入引发的一个线上T0级别事故(真的以后得避坑)
-
如何理解 HTTP 是无状态的,以及它与 Cookie 和 Session 之间的联系
-
HTTP、HTTPS、Cookie 和 Session 之间的关系
-
使用 Spring 框架构建 MVC 应用程序:初学者教程
-
有缺陷的 Java 代码:Java 开发人员最常犯的 10 大错误
-
Java Spring 中常用的 @PostConstruct 注解使用总结
-
线程 vs 虚拟线程:深入理解及区别
-
深度解读 JDK 8、JDK 11、JDK 17 和 JDK 21 的区别
-
10大程序员提升代码优雅度的必杀技,瞬间让你成为团队宠儿!
-
探索 Lombok 的 @Builder 和 @SuperBuilder:避坑指南(一)
-
为什么用了 @Builder 反而报错?深入理解 Lombok 的“暗坑”与解决方案(二)
相关文章:
Java中的Stream API:从入门到实战
引言 在现代Java开发中,Stream API 是处理集合数据的强大工具。它不仅让代码更加简洁易读,还能通过并行处理提升性能。本文将带你从基础概念入手,逐步深入Stream API的使用,并通过实战案例展示其强大功能。 1. 什么是Stream API…...
QPainter绘制3D 饼状图
先展示图片 核心代码如下: pie.h #ifndef Q3DPIE_H #define Q3DPIE_H#include <QtGui/QPen> #include <QtGui/QBrush>class Pie { public:double value; QBrush brush; QString description; double percentValue;QString p…...
【FAQ】HarmonyOS SDK 闭源开放能力 —Live View Kit (1)
1.问题描述: 客户端创建实况窗后,通过Push kit更新实况窗内容,这个过程是自动更新的还是客户端解析push消息数据后填充数据更新?客户端除了接入Push kit和创建实况窗还需要做什么工作? 解决方案: 通过Pu…...
数据治理与管理
引入 上一篇我们聊了数仓架构设计,它是企业构建数据中台的基石。其本质就是构建一个可靠易用的架构,可以借此将原始数据汇聚、处理,最终转换成可消费使用的数据资源。 在拥有数据资源以后,我们就需要考虑如何利用它,为企业创造价值,让它变成企业的资产而不是负担。也就…...
什么是HTTP/2协议?NGINX如何支持HTTP/2并提升网站性能?
HTTP/2是一种用于在Web浏览器和服务器之间进行通信的协议,旨在提高网站性能和加载速度。它是HTTP/1.1的继任者,引入了许多优化和改进,以适应现代Web应用的需求。HTTP/2的主要目标是减少延迟、提高效率,以及更好地支持并发请求。 …...
安全运维,等保测试常见解决问题。
1. 未配置口令复杂度策略。 # 配置密码安全策略 # vi /etc/pam.d/system-auth # local_users_only 只允许本机用户。 # retry 3 最多重复尝试3次。 # minlen12 最小长度为12个字符。 # dcredit-1 至少需要1个数字字符。 # ucredit-1 至少需要1个大…...
jmeter接口测试(二)
一、不同参数类型的接口测试 二、动态参数接口处理 随机数 工具——>函数助手对话框(Random 1000-10000之间的随机数 变量名为rdn)如下图所示 把上图生成的函数字符串复制到想要使用的地方如下图 三、断言 1、状态断言,200 不能证明…...
Keil ARM Complier Missing Compiler Version 5
使用Keil软件时出现了编译时报错,找不到对应的ARM版本,报错Target Target 1 uses ARM-Compiler Default Compiler Version 5 which is not available. *** Please review the installed ARM Compiler Versions: Manage Project Items - Folders/Extensions to manage ARM Compi…...
【僵尸进程】
【僵尸进程】 目录:知识点1. 僵尸进程的定义2. 僵尸进程产生的原因3. 僵尸进程的危害4. 如何避免僵尸进程 代码示例产生僵尸进程的代码示例避免僵尸进程的代码示例(父进程主动回收)避免僵尸进程的代码示例(信号处理) 运…...
【框架】参考 Spring Security 安全框架设计出,轻量化高可扩展的身份认证与授权架构
关键字:AOP、JWT、自定义注解、责任链模式 一、Spring Security Spring Security 想必大家并不陌生,是 Spring 家族里的一个安全框架,特别完善,但学习成本比较大,不少开发者都觉得,这个框架“很重” 他的…...
【Git 学习笔记_27】DIY 实战篇:利用 DeepSeek 实现 GitHub 的 GPG 密钥创建与配置
文章目录 1 前言2 准备工作3 具体配置过程3.1. 本地生成 GPG 密钥3.2. 导出 GPG 密钥3.3. 将密钥配置到 Git 中3.4. 测试提交 4 问题排查记录5 小结与复盘 1 前言 昨天在更新我的第二个 Vim 专栏《Mastering Vim (2nd Ed.)》时遇到一个经典的 Git 操作问题:如何在 …...
微信小程序地图map全方位解析
微信小程序地图map全方位解析 微信小程序的 <map> 组件是一个功能强大的工具,可以实现地图展示、定位、标注、路径规划等多种功能。以下是全方位解析微信小程序地图组件的知识点: 一、地图组件基础 1. 引入 <map> 组件 在页面的 .wxml 文…...
调试无痛入手
在调试过程中,Step In、Step Over 和 Step Out 是控制代码执行流程的常用操作,帮助开发者逐行或逐块检查代码行为。以下是它们的详细介绍及使用方法: 1. Step In 功能:进入当前行的函数或方法内部,逐行执行其代码。使…...
【蓝桥杯集训·每日一题2025】 AcWing 6135. 奶牛体检 python
6135. 奶牛体检 Week 1 2月21日 农夫约翰的 N N N 头奶牛站成一行,奶牛 1 1 1 在队伍的最前面,奶牛 N N N 在队伍的最后面。 农夫约翰的奶牛也有许多不同的品种。 他用从 1 1 1 到 N N N 的整数来表示每一品种。 队伍从前到后第 i i i 头奶牛的…...
AI发展迅速,是否还有学习前端的必要性?
今天有个小伙伴跟我讨论:“现在 AI 发展迅速,是否还有学习 JS 或者 TS 及前端知识的必要?” 我非常肯定地说: 是的,学习 JavaScript/TypeScript 以及前端知识仍然非常必要,而且在可预见的未来,…...
【数据标准】数据标准化是数据治理的基础
导读:数据标准化是数据治理的基石,它通过统一数据格式、编码、命名与语义等,全方位提升数据质量,确保准确性、完整性与一致性,从源头上杜绝错误与冲突。这不仅打破部门及系统间的数据壁垒,极大促进数据共享…...
VS2022配置FFMPEG库基础教程
1 简介 1.1 起源与发展历程 FFmpeg诞生于2000年,由法国工程师Fabrice Bellard主导开发,其名称源自"Fast Forward MPEG",初期定位为多媒体编解码工具。2004年后由Michael Niedermayer接任维护,逐步发展成为包含音视频采…...
three.js之特殊材质效果
*案例42 创建一个透明的立方体 <template><div ref"container" className"container"></div> </template><script setup> import * as THREE from three; import WebGL from three/examples/jsm/capabilities/WebGL.js // 引…...
Qt常用控件之日历QCalendarWidget
日历QCalendarWidget QCalendarWidget 是一个日历控件。 QCalendarWidget属性 属性说明selectDate当前选中日期。minimumDate最小日期。maximumDate最大日期。firstDayOfWeek设置每周的第一天是周几(影响日历的第一列是周几)。gridVisible是否显示日历…...
vxe-table 如何实现跟 Excel 一样的数值或金额的负数自动显示红色字体
vxe-table 如何实现跟 Excel 一样的数值或金额的负数自动显示红色字体,当输入的值为负数时,会自动显示红色字体,对于数值或者金额输入时该功能就非常有用了。 查看官网:https://vxetable.cn gitbub:https://github.co…...
我烧了50万GPU小时后悟出的模型蒸馏真理:一份给软件测试从业者的思维启示
在耗费了天文数字般的算力资源,经历了无数次从希望到挫败,再到顿悟的循环之后,我对“模型蒸馏”这项技术的认知,早已超越了技术手册上的冰冷定义。它不再仅仅是一种将庞大教师模型的知识迁移到轻巧学生模型的技术路径,…...
tao-8k开源Embedding模型实测:对比BGE、text2vec等主流模型效果
tao-8k开源Embedding模型实测:对比BGE、text2vec等主流模型效果 1. 引言:为什么需要长文本Embedding模型 在日常的文本处理任务中,我们经常需要将文字转换为数值向量,这就是Embedding模型的作用。传统的Embedding模型通常只能处…...
打卡信奥刷题(3142)用C++实现信奥题 P7635 [COCI 2010/2011 #5] DVONIZ
P7635 [COCI 2010/2011 #5] DVONIZ 题目描述 当前 K K K 个元素的和与最后 K K K 个元素的和都不大于 S S S 时,我们说这个 2 K 2\times K 2K 个元素的序列是有趣的。 给出一个长度为 N N N 的序列 A A A。对于每个元素,输出从该元素开始的最长…...
unity mcp接入 实现一句话生成游戏!
文章目录前言一、MCP 核心包接入 Unity 编辑器1、使用Git URL 安装(可选,最新)2、Unity Asset Store 安装(可选,稳定)2、OpenUPM(可选)二、Python 3.10 与 uv 环境搭建1、安装 Pyth…...
Excel中的UNIQUE和SORT函数实战解析
在日常工作中,Excel作为数据处理和分析的利器,经常遇到需要处理重复数据或进行数据排序的需求。最近,我在StackOverflow上看到一个关于使用Excel中的UNIQUE()和SORT()函数的问题,引发了我对这些函数更深入的思考。本文将通过这个实际案例,详细探讨如何使用这些函数来实现数…...
G-Helper终极指南:如何免费释放华硕ROG笔记本的全部性能潜力
G-Helper终极指南:如何免费释放华硕ROG笔记本的全部性能潜力 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Str…...
nli-MiniLM2-L6-H768保姆级教程:Docker镜像体积优化至<1.2GB的技巧
nli-MiniLM2-L6-H768保姆级教程:Docker镜像体积优化至<1.2GB的技巧 1. 模型简介与核心优势 nli-MiniLM2-L6-H768是一款专为自然语言推理(NLI)与零样本分类设计的轻量级交叉编码器(Cross-Encoder)模型。它在保持高性能的同时,通过精巧的设计实现了体…...
从标注文件看CV任务演进:COCO的bbox、segmentation和keypoints字段都怎么用?
COCO标注文件解析:从边界框到关键点的视觉任务演进 计算机视觉领域的研究者和工程师们每天都在与各种标注数据打交道,而COCO数据集无疑是这个领域最具影响力的基准之一。不同于简单地介绍JSON文件结构,我们将从任务演进的视角,深入…...
别再被‘Already up-to-date’骗了!手把手教你用git status和git reset解决文件不更新的坑
当Git说"Already up-to-date"却未更新文件时,如何彻底解决这个陷阱 你是否遇到过这样的情况:执行git pull后,终端愉快地告诉你"Already up-to-date",但当你打开文件时,却发现内容根本没有更新&…...
告别黑盒:手把手教你用AssetStudio查看并导出Unity打包后的游戏UI与图片素材
告别黑盒:手把手教你用AssetStudio查看并导出Unity打包后的游戏UI与图片素材 当你被一款游戏的精美UI设计所吸引时,是否好奇过这些视觉元素是如何实现的?作为UI设计师或独立开发者,学习逆向分析成熟作品的资源结构,是提…...
