【从零开始学习JAVA | 第二十九篇】Stream流

目录

前言:

Stram流:

设计目标:

使用步骤:

1.先得到一条Stream流,并把数据放上去。

2.利用Stream流中的各种API进行操作。

使用Stream流的注意事项:

总结:


前言:

        本文我们将学习Stream流,他就像流水线一样,可以对我们要处理的对象进行逐步处理,最终达到我们想要的效果,是JAVA中的一大好帮手,值得我们了解和掌握。

Stram流:

        Stream流的核心思想是函数式编程它倡导将数据处理过程看作是一系列的转换操作。这种思想与传统的命令式编程方式不同,传统的命令式编程方式强调对数据的直接操作,而函数式编程则更加注重对数据的转换和操作过程。

在使用Stream流时,我们可以将数据源(如集合或数组)看作是一组元素的流,通过一系列的中间操作(如过滤、映射、排序等),最终到达终止操作(如匹配、归约、收集等)来处理数据。

设计目标:

        Stream流的设计目标是提供一种简洁、高效的数据处理方式,使得代码更加可读、易于理解和维护。它的思想是将数据处理过程分解为多个步骤,每个步骤都是一种转换操作,可以对数据进行过滤、映射、排序等操作,最终得到所需要的结果。

        通过使用Stream流,我们可以避免传统的循环和条件判断,将复杂的数据处理逻辑转化为简洁、清晰的方法链式调用,使得代码更加简洁和可读。

        另外,Stream流还支持并行处理,可以将大数据集划分为多个子集并行执行操作,提高处理效率。这种并行处理的方式可以很好地利用多核处理器的优势,使得数据处理更加高效。

        总而言之,Stream流的思想是通过函数式编程的方式,将数据处理过程看作是一系列的转换操作,实现简洁、高效和易于理解的数据处理。它的设计目标是提供一种优雅和强大的数据处理方式,使得开发人员能够更加专注于数据转换的逻辑,而无需关心底层的迭代和条件判断。一般情况下,Stream流会搭配Lambda表达式一起运用,以此来简化集合和数组的操作

使用步骤:

举例:

例如我们想在一堆存储在list中的数据中找到首字为“张”的数据,按照传统的写法来讲,我们需要手动遍历每一个数据,再利用list中的API进行判断首字母,但是Stream流的出现,大大便捷了我们的操作

import java.util.ArrayList;public class test01 {public static void main(String[] args) {ArrayList<String> list1 = new ArrayList<>();list1.add("张无忌");list1.add("赵敏");list1.add("张强");list1.add("刘三丰");//传统方法for (String s : list1) {if(s.startsWith("张")){System.out.println(s);}}//直接调用stream流list1.stream().filter(name->name.startsWith("张")).forEach(name->System.out.println(name));}
}

从这个例子中我们可以总结出调用stream流的两步骤:

1.先得到一条Stream流,并把数据放上去。

2.利用Stream流中的各种API进行操作。

1. filter(Predicate<T> predicate):根据指定的条件过滤流中的元素,返回一个新的流。

2. map(Function<T, R> mapper):对流中的每个元素进行映射操作,返回一个新的流,新流中的元素为映射后的结果。

3. sorted():对流中的元素进行默认排序。

4. sorted(Comparator<T> comparator):对流中的元素按照指定的规则进行排序。

5. distinct():去除流中的重复元素,返回一个新的流。

6. limit(long maxSize):截断流,获取前几个元素。

7. skip(long n):跳过指定数量的元素,返回一个新的流。

8. forEach(Consumer<T> action):对流中的每个元素执行指定的操作。

9. collect(Collector<T, A, R> collector):将流中的元素收集到一个结果集合中。

10. anyMatch(Predicate<T> predicate):判断流中是否有满足指定条件的元素。

11. allMatch(Predicate<T> predicate):判断流中的所有元素是否都满足指定条件。

12. noneMatch(Predicate<T> predicate):判断流中是否没有满足指定条件的元素。

13. findFirst():返回流中的第一个元素。

14. findAny():返回流中的任意一个元素。

15. reduce(BinaryOperator<T> accumulator):将流中的元素按照指定的规约操作进行归约。

16. parallelStream():返回一个并行流,可以并行地处理流中的元素。

使用Stream流的注意事项:

1. Stream流是一次性使用的:一旦对Stream流进行终止操作(如forEach、collect等),就不能再对同一个Stream流进行其他操作。如果需要对同一组数据进行多个处理步骤,需要创建新的Stream流。

2. 注意流的顺序:Stream流的中间操作顺序是很重要的,它们会按照顺序被应用到数据上。因此,在对流进行操作时,请确保中间操作的顺序是正确的,以避免出现错误的结果。

3. 及早终止流:Stream流提供了许多终止操作,如forEach、collect、reduce等。在使用这些终止操作时,应尽量避免无限循环或大量计算及早终止流以避免性能问题。

4. 注意流的惰性求值:Stream流采用惰性求值的方式,即在终止操作之前,中间操作不会立即执行。这种机制可以提高性能,但也需要注意在需要及时执行的情况下使用及时触发的操作如count、findFirst等。

5. 避免空指针异常:在对流进行操作时,需要注意空值(null)的情况,使用过滤操作时,需要考虑到空元素的处理,避免出现空指针异常。

6. 并行流需谨慎使用:Stream流支持并行处理,可以通过parallelStream方法来获得并行流。但在使用并行流时,需要注意线程安全和性能问题,确保代码在并行执行时不会出现竞态条件或导致性能下降。

7. 适度使用流操作:Stream流提供了丰富的操作方法,但并不意味着所有情况下都应该使用流操作。在简单的数据处理场景中,使用传统的循环方式可能更加直观和高效。

总结:

        Stream流常常与lambda表达式以及链式编程的思想结合起来,大大降低了代码的繁杂程度,是一个很好的选择,但是他的缺点就是降低了代码的可读性,因此我们要合理的使用Stream流,在效率与可读性之间做好一个把握。

如果我的内容对你有帮助,请点赞,评论,收藏。创作不易,大家的支持就是我坚持下去的动力!

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/26579.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vue3 前端编码规范

prettier 配置 1. vscode 安装prettier 的 插件 2. 新建 .prettierrc 文件 {"semi": false, // 不尾随分号"singleQuote": true, // 使用单引号"trailingComma": "none" // 多行逗号分隔的语法&#xff0c;最后一行不加逗号 }eslin…

《远见》阅读笔记

不同的环境&#xff0c;不同的职业&#xff0c;职业生涯的建议并没有什么不同 找到热爱的工作&#xff0c;建立热爱的生活 如何思考职业远景 如何分配时间 如何扩张人脉 职业生涯决策框架 三个部分 职场思维、框架、工具实用性建议和案例现实生活为基础&#xff0c;平衡职…

Animboat Application Framework

SpringBoot的服务将部署在云端 管理云端数据和处理分布式的业务请求 本地基础服务将作为云端和终端中间媒介&#xff0c; 与局域网内其它dcc 插件或者app运行实例进行通信&#xff0c; 同时本地基础服务将负责本地数据的管理。 每个AppInstance都会有自己的FlaskSvr用于与Loc…

Acrel-1000DP分布式光伏系统在重工企业的应用

安科瑞 崔丽洁 摘 要&#xff1a;分布式光伏发电特指在用户场地附近建设&#xff0c;运行方式以用户侧自发自用、余电上网&#xff0c;且在配电系统平衡调节为特征的光伏发电设施&#xff0c;是一种新型的、具有广阔发展前景的发电和能源综合利用方式&#xff0c;它倡导就近发电…

【云原生】Docker网络Overlay搭建Consul实现跨主机通信

目录 1.overlay网络是什么&#xff1f; 实现overlay环境 1.overlay网络是什么&#xff1f; 在Docker中&#xff0c;Overlay网络是一种容器网络驱动程序&#xff0c;它允许在多个Docker主机上创建一个虚拟网络&#xff0c;使得容器可以通过这个网络相互通信。 Overlay网络使用…

字符串函数及内存函数C语言

字符函数及内存函数 一.字符串函数函数1.strlen函数2.strcpy函数3.strcat函数4.strcmp函数5.strncpy函数6.strncat函数7.strncmp函数8.strstr函数9.strtok函数10.strerror函数 二.内存函数1.memcpy函数2.memmove函数3.memcpy函数4.memset函数 一.字符串函数函数 1.strlen函数 …

【程序员必须掌握哪些算法?】

一个程序员一生中可能会邂逅各种各样的算法&#xff0c;但总有那么几种&#xff0c;是作为一个程序员一定会遇见且大概率需要掌握的算法。今天就来聊聊这些十分重要的“必抓&#xff01;”算法吧~ 常见算法介绍 本文所介绍的排序算法均以升序为例。 文章目录 常见算法介绍一 …

P106-100组A卡(R5 240)指南

P106-100组A卡&#xff08;R5 240&#xff09;指南 不建议小白尝试 不建议小白尝试 不建议小白尝试文章目录 P106-100组A卡&#xff08;R5 240&#xff09;指南资料合集硬件软件基础卸载所有原驱动安装驱动修改注册表自动调用——只改一个注册表手动调用——改两个注册表 劝退…

Qt中QMainWindow的相关介绍

目录 菜单栏 工具栏 状态栏&#xff1a; 停靠窗口&#xff1a; QMainWindow 是标准基础窗口中结构最复杂的窗口&#xff0c;其组成如下: 提供了菜单栏 , 工具栏 , 状态栏 , 停靠窗口 菜单栏&#xff1a;只能有一个&#xff0c;位于窗口的最上方 工具栏&#xff1a;可以有多…

攻不下dfs不参加比赛(十四)

标题 为什么练dfs题目为什么练dfs 相信学过数据结构的朋友都知道dfs(深度优先搜索)是里面相当重要的一种搜索算法,可能直接说大家感受不到有条件的大家可以去看看一些算法比赛。这些比赛中每一届或多或少都会牵扯到dfs,可能提到dfs大家都知道但是我们为了避免眼高手低有的东…

软件体系结构-KWIC索引系统

引言 KWIC作为一个早年间在ACM的Paper提出的一个问题&#xff0c;被全世界各个大学的软件设计课程奉为课堂讲义或者作业的经典。&#xff08;From Wiki&#xff0c;FYI&#xff0c;D. L. Parnas uses a KWIC Index as an example on how to perform modular design in his pap…

MySQL(三)SQL优化、Buffer pool、Change buffer

MySQL系列文章 MySQL&#xff08;一&#xff09;基本架构、SQL语句操作、试图 MySQL&#xff08;二&#xff09;索引原理以及优化 MySQL&#xff08;三&#xff09;SQL优化、Buffer pool、Change buffer MySQL&#xff08;四&#xff09;事务原理及分析 MySQL&#xff08;五&a…