发布时间:2023-09-14 12:00
Stream 是 Java8 中处理**集合、数组**的关键抽象概念,它可以指定你希望对集合进行的操作,可以执行非常复杂的查找、过滤和映射数据等操作。
使用Stream API 对集合数据进行操作,就类似于使用 SQL 执行的数据库查询。也可以使用 Stream API 来并行执行操作。
简而言之,Stream API 提供了一种高效且易于使用的处理数据的方式。
注意:
- Stream 自己不会存储元素。
- Stream 不会改变源对象。相反,他们会返回一个持有结果的新Stream。
- Stream 操作是延迟执行的。这意味着他们会等到需要结果的时候才执行。
(一)、 获取/创建Stream
1. 通过Collection 系列集合提供stream
2. 通过数组提供流
3. 通过Stream类中静态方法创建流
4. 通过Stream类的 public static
5. 通过Stream类的 public static
返回值 |
方法和参数 |
说明 |
Stream |
filter(Predicate super T> predicate) |
从流中排除某些元素 |
Stream |
limit(long maxSize) |
截断流,使其元素不超过给定数量。 |
Stream |
skip(long n) |
跳过元素,返回一个扔掉了前 n 个元素的流。若流中元素不足 n 个,则返回一个空流。与 limit(n) 互补 |
Stream |
distinct() |
去除重复元素,通过流所生成元素的 hashCode() 和 equals() 去除重复元素 |
(二)、筛选与切片方法
(三)、映射方法
返回值 |
方法和参数 |
说明 |
R |
collect(Collector super T, A, R> collector) |
将流转换为其他形式。接收一个 Collector接口的实现,用于给Stream中元素做汇总的方法 |
Object[] |
toArray() |
将流转换为数组 |
(四)、排序
返回值 |
方法和参数 |
说明 |
Stream |
sorted() |
无参,自然排序 |
Stream |
sorted(Comparator super T> comparator) |
自定义排序 |
Python 多线程小技巧:比 time.sleep 更好用的暂停写法!
初学算法的小菜鸡 - 自学笔记 (第十一天): 链表相关算法(一) 反转链表Leetcode 206题
EventBridge 在 SaaS 企业集成领域的探索与实践
python windows linux github 开发_深入体验bash on windows!在windows上搭建原生的linux开发环境...
PyTorch 深度剖析:并行训练的DP和DDP分别在什么情况下使用及实例
【Spring从入门到精通】03-JdbcTemplate与声明式事务
Zilliz x 2022 开源之夏!来 Milvus 和 Towhee 社区,搞开源,拿奖金!
php开发为什么要使用docker,Docker? 为什么要使用Docker?
利用Python实现新冠疫情数据可视化(获取疫情历史数据,制作南丁格尔玫瑰图、疫情地图、动态疫情组合图、词云)
给python 安装torch模块或者添加库链接下载torch
Spring Boot 深入分析AutoConfigurationImportFilter自动化条件配置源码