Java8 Stream流的基本使用

news/2024/9/17 3:33:55/ 标签: java

Java 8 中引入的 Stream API 是为了简化对集合类库(例如 ListSet)的操作,同时支持声明式编程风格和并行操作。Stream 不存储数据,而是对数据源进行流水线式操作,其设计核心是“将数据处理的每一步链接起来,并将操作延迟到最终需要结果时执行”。

以下是 Java 8 Stream 流的详细介绍,包括其创建、常用操作和示例代码。

1. Stream 的创建

Stream 可以通过多种方式创建,主要有以下几种方式:

1.1 通过集合(如 ListSet)创建流
java">List<String> list = Arrays.asList("apple", "banana", "cherry");
Stream<String> stream = list.stream();
1.2 通过数组创建流
java">String[] arr = {"apple", "banana", "cherry"};
Stream<String> stream = Arrays.stream(arr);
1.3 通过 Stream.of() 创建流
java">Stream<String> stream = Stream.of("apple", "banana", "cherry");
1.4 通过 Stream.generate() 创建无限流
java">Stream<Double> randoms = Stream.generate(Math::random).limit(10);
1.5 通过 Stream.iterate() 创建无限流
java">Stream<Integer> numbers = Stream.iterate(0, n -> n + 2).limit(10);

2. Stream 的操作类型

Stream 操作分为两类:

  • 中间操作:返回一个新的 Stream,可以进行链式调用,常见的有 filtermapsorted 等。
  • 终端操作:执行实际计算并返回结果,常见的有 forEachreducecollectcount 等。
2.1 中间操作
2.1.1 filter()

filter() 用于过滤掉不符合条件的元素。

java">List<String> result = list.stream().filter(s -> s.startsWith("a")).collect(Collectors.toList());
2.1.2 map()

map() 用于将元素映射到另一个元素,通常用于类型转换或数据提取。

java">List<Integer> lengths = list.stream().map(String::length).collect(Collectors.toList());
2.1.3 sorted()

sorted() 用于对流中的元素进行排序,可以是自然排序,也可以是自定义排序。

java">List<String> sortedList = list.stream().sorted().collect(Collectors.toList());
2.1.4 distinct()

distinct() 用于去除流中的重复元素。

java">List<String> distinctList = list.stream().distinct().collect(Collectors.toList());
2.1.5 limit()

limit() 用于截断流,使其不超过给定数量。

java">List<String> limitedList = list.stream().limit(2).collect(Collectors.toList());
2.1.6 skip()

skip() 用于跳过前 n 个元素。

java">List<String> skippedList = list.stream().skip(1).collect(Collectors.toList());
2.2 终端操作
2.2.1 forEach()

forEach() 用于对流中的每个元素执行一个操作。一般用于遍历流元素。

java">list.stream().forEach(System.out::println);
2.2.2 collect()

collect() 是终端操作之一,用于将流中的元素汇总成一个集合或其它结果类型。

java">List<String> result = list.stream().filter(s -> s.length() > 5).collect(Collectors.toList());
2.2.3 reduce()

reduce() 是一种聚合操作,常用于将流中的元素组合成一个值。

java">int sum = Stream.of(1, 2, 3, 4).reduce(0, Integer::sum);
2.2.4 count()

count() 用于返回流中元素的个数。

java">long count = list.stream().count();
2.2.5 findFirst()findAny()
  • findFirst() 返回流中的第一个元素(Optional 类型)。
  • findAny() 返回流中任意一个元素(适用于并行流时)。
java">Optional<String> first = list.stream().findFirst();
2.2.6 anyMatch()allMatch()noneMatch()
  • anyMatch() 用于检查是否有至少一个元素匹配给定的条件。
  • allMatch() 用于检查是否所有元素都匹配给定的条件。
  • noneMatch() 用于检查是否没有元素匹配给定的条件。
java">boolean anyMatch = list.stream().anyMatch(s -> s.startsWith("a"));

3. 并行流

Java 8 的 Stream 提供了并行处理能力,parallelStream() 可以实现流的并行处理,提高性能,尤其在大数据量处理时非常有用。

3.1 创建并行流
java">List<String> list = Arrays.asList("apple", "banana", "cherry");
list.parallelStream().forEach(System.out::println);

4. 综合示例

下面是一个综合示例,展示如何使用流操作对一个字符串列表进行过滤、排序和收集操作:

java">List<String> list = Arrays.asList("apple", "banana", "cherry", "date", "elderberry");// 使用 Stream 进行一系列操作
List<String> result = list.stream().filter(s -> s.length() > 5)  // 过滤长度大于5的字符串.sorted()                     // 排序.map(String::toUpperCase)      // 转换为大写.collect(Collectors.toList()); // 收集结果System.out.println(result);  // 输出: [BANANA, CHERRY, ELDERBERRY]

5. Stream API 常用 Collectors

Collectors 提供了多种汇总流数据的方式,以下是一些常见的 Collectors 使用方式:

5.1 toList()

将流中的元素收集到 List 中:

java">List<String> list = stream.collect(Collectors.toList());
5.2 toSet()

将流中的元素收集到 Set 中:

java">Set<String> set = stream.collect(Collectors.toSet());
5.3 joining()

将流中的字符串连接为一个字符串:

java">String result = stream.collect(Collectors.joining(", "));
5.4 groupingBy()

根据某个条件将元素分组:

java">Map<Integer, List<String>> groupedByLength = stream.collect(Collectors.groupingBy(String::length));
5.5 partitioningBy()

将流中的元素根据布尔条件分为两组:

java">Map<Boolean, List<String>> partitioned = stream.collect(Collectors.partitioningBy(s -> s.length() > 5));

总结

Java 8 Stream API 提供了非常强大的声明式操作集合的方式。通过中间操作可以实现复杂的流水线式操作,终端操作则负责最终的结果计算。Stream API 简化了数据处理逻辑,特别是通过并行流可以提高性能,使得处理大数据集变得更加高效和直观。


http://www.ppmy.cn/news/1521967.html

相关文章

kubernetes集群下部署kafka+zookeeper单机部署方案

背景&#xff1a; 注&#xff1a;在kubernetes集群上部署单机版的zookeeperkafka服务&#xff0c;是采用了kubernetes中的deploment组件service组件pvc存储组件 1、部署zookeeper服务&#xff1a; 注&#xff1a;这里时候的镜像是&#xff1a;dockerhub.jiang.com/jiang-public…

【佳学基因检测】如何使用Letsencrypt对一个网站进行加密?

【佳学基因检测】如何使用Letsencrypt对一个网站进行加密&#xff1f; 更换为Let’s Encrypt证书涉及以下几个步骤&#xff1a; 1. 安装Certbot Certbot是Let’s Encrypt的客户端工具&#xff0c;它可以帮助你申请和管理证书。首先&#xff0c;你需要在服务器上安装Certbot。…

[C++11#45](二) 右值引用 | 移动语义 | 万能引用 | 完美转发forward | 初识lambda

目录 一. 右值引用 1.左值 vs 右值 2.左值引用 vs 右值引用 右值引用实现的两种底层优化 Q1&#xff1a; 容器上 Q2&#xff1a; 字符串上 解决&#xff1a;右值引用 3.完美转发 完美转发 4.补充 1.移动赋值 2.右值引用引用左值的场景 二.lambda 1.引入 2.lambd…

无人机之载重篇

无人机的载重能力是一个复杂且多样化的参数&#xff0c;它受到多种因素的影响&#xff0c;包括无人机的类型、设计、技术规格以及用途等。以下是对无人机载重能力的详细解析&#xff1a; 一、无人机载重能力的差异 无人机的载重能力差异很大&#xff0c;从几百克到几十千克不等…

Java后端分布式系统的服务容错机制:Faul-tolerant Systems

Java后端分布式系统的服务容错机制&#xff1a;Faul-tolerant Systems 大家好&#xff0c;我是微赚淘客返利系统3.0的小编&#xff0c;是个冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; 在构建分布式系统时&#xff0c;服务的容错性是确保系统稳定性和可用性的…

安宝特科技 | AR眼镜在安保与安防领域的创新应用及前景

随着科技的不断进步&#xff0c;增强现实&#xff08;AR&#xff09;技术逐渐在多个领域展现出其独特的优势&#xff0c;尤其是在安保和安防方面。AR眼镜凭借其先进的功能&#xff0c;在机场、车站、海关、港口、工厂、园区、消防局和警察局等行业中为安保人员提供了更为高效、…

TCP 和 UDP 区别

UDP UDP&#xff08;用户数据报协议&#xff0c;User Datagram Protocol&#xff09;是一种无连接的网络传输协议&#xff0c;提供了简单的消息传送服务。UDP位于传输层&#xff0c;允许应用程序向其他主机发送封装在IP数据报中的消息&#xff0c;而无需先建立连接。由于UDP不…

【论文笔记】Multi-Task Learning as a Bargaining Game

Abstract 本文将多任务学习中的梯度组合步骤视为一种讨价还价式博弈(bargaining game)&#xff0c;通过游戏&#xff0c;各个任务协商出共识梯度更新方向。 在一定条件下&#xff0c;这种问题具有唯一解(Nash Bargaining Solution)&#xff0c;可以作为多任务学习中的一种原则…

I2VGen-XL模型构建指南

一、介绍 VGen可以根据输入的文本、图像、指定的运动、指定的主体&#xff0c;甚至人类提供的反馈信号生成高质量的视频。它还提供了各类常用的视频生成模型工具&#xff0c;例如可视化、采样、训练、推理、使用图像和视频的联合训练&#xff0c;加速等各类工具和技术。 &quo…

微信小程序显示后台文章副文本,图片和视频正常显示

解决方案: 使用 wxParse 或 rich-text 组件: 这两种方式可以解析 HTML 字符串并渲染富文本内容&#xff0c;包括图片和视频。 数据处理: 将后台返回的富文本数据进行处理&#xff0c;提取出图片和视频的链接&#xff0c;并将其转换成小程序支持的格式。 方案一&#xff1a;使…

数据库学习01——mysql怎么创建数据库和表

第一步&#xff1a;创建数据库 使用 create database 语句&#xff0c;后跟要创建的数据库名称&#xff1a; CREATE DATABASE dbname;例如&#xff0c;要创建名为 my_db 的数据库&#xff0c;请输入&#xff1a; CREATE DATABASE my_db ;使用 show databases; 语句检查数据库是…

第十六篇:走入计算机网络的传输层--传输层概述

1. 传输层的功能 ① 分割与重组数据 一次数据传输有大小限制&#xff0c;传输层需要做数据分割&#xff0c;所以在数据送达后必然也需要做数据重组。 ② 按端口号寻址 IP只能定位数据哪台主机&#xff0c;无法判断数据报文应该交给哪个应用&#xff0c;传输层给每个应用都设…

Java基础 ——线程

多线程 并行和并发 需求&#xff1a;边打英雄联盟和边听音乐 问题&#xff1a;只能先后关系&#xff0c;并不能同时发生 多进程或者多线程来解决 并行和并发&#xff1a; 并行&#xff1a;多件事情在同一时刻发生 并发&#xff1a;多件事情在同一时间段发生&#xff0c;同一…

无线信道中ph和ph^2的场景

使用 p h ph ph的情况&#xff1a; Rayleigh 分布的随机变量可以通过两个独立且相同分布的零均值、高斯分布的随机变量表示。设两个高斯随机变量为 X ∼ N ( 0 , σ 2 ) X \sim \mathcal{N}(0, \sigma^2) X∼N(0,σ2)和 Y ∼ N ( 0 , σ 2 ) Y \sim \mathcal{N}(0, \sigma^2)…

回归预测 | Matlab基于贝叶斯算法优化XGBoost(BO-XGBoost/Bayes-XGBoost)的数据回归预测+交叉验证

回归预测 | Matlab基于贝叶斯算法优化XGBoost(BO-XGBoost/Bayes-XGBoost)的数据回归预测交叉验证 目录 回归预测 | Matlab基于贝叶斯算法优化XGBoost(BO-XGBoost/Bayes-XGBoost)的数据回归预测交叉验证效果一览基本介绍程序设计参考资料 效果一览 基本介绍 Matlab实现基于贝叶…

端口安全老化细节

我们都知道port-security aging-time命令用来配置端口安全动态MAC地址的老化时间&#xff0c;但是后面还可以加上类型&#xff1a; [SW1-GigabitEthernet0/0/1]port-security aging-time 5 type absolute Absolute time 绝对老化 inactivity Inactivity time相对老化 …

详解 HTTPS 与 TLS证书链校验

一文详解 HTTPS 与 TLS证书链校验_证书链怎么验证-CSDN博客 深入浅出 SSL/CA 证书及其相关证书文件&#xff08;pem、crt、cer、key、csr&#xff09; https://zhuanlan.zhihu.com/p/702745054

ASP.NET Core 入门教学十七 GraphQL入门指南

GraphQL 是一种用于 API 的查询语言&#xff0c;允许客户端请求所需的数据&#xff0c;并能够合并多个资源到一个请求中。在 ASP.NET Core 中使用 GraphQL 可以提供更灵活、高效和实用的数据查询方式。以下是 ASP.NET Core 中 GraphQL 的入门指南&#xff1a; 1. 安装必要的 N…

【Android】程序开发组件—探究Jetpack

引言 Jetpack是一个开发组件工具集&#xff0c;它的主要目的是帮助我们编写出更加简洁的代码&#xff0c;并简化我们的开发过程&#xff0c;在这么多的组件当中&#xff0c;最需要我们关注的其实还是架构组件&#xff0c;接下来就对Jetpack的主要架构组件进行学习&#xff01;…

Jmeter终极线程组“Ultimate Thread Group“如何使用?

1、安装,点击"选项"&#xff0c;再点击"Plugins Manager"&#xff0c;下载"Custom Thread Groups" 2、添加"jpgc - Ultimate Thread Group" 3、"jpgc - Ultimate Thread Group"使用