Java Stream:让你的集合操作如丝般顺滑

Stream API是一种基于流(stream)的API,它提供了一种简洁而高效的处理集合和数组的方法。使用Stream API可以将集合和数组中的数据进行过滤、转换和聚合等操作,同时避免了使用传统的for循环或迭代器的冗长代码.

kotlin 可参考Kotlin Collection KTX:让你的集合操作如丝般顺滑

为什么使用stream API

  1. java 开发中想要使用kotlin 的集合操作方式,可以使用它。
  2. 简洁高效:Stream API提供了一种简洁而高效的处理集合和数组的方法,代码更加简洁易读,同时也提高了执行效率。
  3. 并行处理:Stream API可以实现并行处理,将数据集分成多个块,并且每个块可以在不同的线程中进行处理,从而加快处理速度。
  4. 延迟执行:Stream API中的操作是延迟执行的,只有在需要返回结果时才会执行,这样可以减少不必要的计算,提高效率。
  5. 可组合性:Stream API中的多个操作可以组合在一起使用,形成一个完整的处理流程,可以减少中间变量的使用,从而使代码更加简洁。

常用API介绍

  1. filter(Predicate predicate) 对流中的元素进行筛选,只保留符合条件的元素。
  2. map(Function<T, R> mapper) 对流中的元素进行映射操作,将每个元素映射成一个新的元素。
  3. flatMap(Function<T, Stream<R>> mapper) 对流中的每个元素进行映射操作,将每个元素映射成一个新的流,并将多个流合并成一个流。
  4. distinct() 去除流中的重复元素。
  5. sorted() 对流中的元素进行排序操作。
  6. limit(long maxSize) 对流进行截取操作,只保留前n个元素。
  7. skip(long n) 对流进行跳过操作,跳过前n个元素。
  8. forEach(Consumer action) 对流中的每个元素执行指定的操作。
  9. reduce(T identity, BinaryOperator accumulator) 对流中的元素进行累加操作,并返回累加结果。
  10. collect(Collector<T, A, R> collector) 将流中的元素收集成一个集合或其他数据结构。
  11. anyMatch(Predicate predicate) 判断流中是否有任意一个元素符合指定条件。
  12. allMatch(Predicate predicate) 判断流中是否所有元素都符合指定条件。
  13. noneMatch(Predicate predicate) 判断流中是否没有任何一个元素符合指定条件。
  14. findFirst() 返回流中的第一个元素。
  15. findAny() 返回流中的任意一个元素。
  16. count() 返回流中元素的总数。
  17. max(Comparator comparator) 返回流中的最大值。
  18. min(Comparator comparator) 返回流中的最小值。
  19. reduce(BinaryOperator accumulator) 对流中的元素进行累加操作,并返回累加结果。
  20. toArray(IntFunction<T[]> generator) 将流中的元素转换成一个数组。

此外,Java Stream API还提供了一些中间操作,比如peek()和sorted()等,这些操作可以在Stream中进行链式调用。其中,peek()方法可以用来对Stream中的每个元素执行一些副作用操作

常用API Demo

  • filter(Predicate predicate) 过滤集合中符合条件的元素,并返回一个新的流。
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> evenNumbers = numbers.stream().filter(n -> n % 2 == 0).collect(Collectors.toList());
System.out.println(evenNumbers); // 输出 [2, 4]
  • map(Function<T, R> mapper) 将集合中的每个元素映射成另一个元素,并返回一个新的流
List<String> names = Arrays.asList("Alice", "Bob", "Charlie");
List<Integer> nameLengths = names.stream().map(String::length).collect(Collectors.toList());
System.out.println(nameLengths); // 输出 [5, 3, 7]
  • flatMap(Function<T, Stream> mapper) 将集合中的每个元素映射成一个流,将所有流中的元素合并成一个新的流
List<List<Integer>> numbers = Arrays.asList(Arrays.asList(1, 2, 3),Arrays.asList(4, 5, 6),Arrays.asList(7, 8, 9)
);
List<Integer> allNumbers = numbers.stream().flatMap(Collection::stream).collect(Collectors.toList());
System.out.println(allNumbers); // 输出 [1, 2, 3, 4, 5, 6, 7, 8, 9]
  • distinct() 去除流中重复的元素,并返回一个新的流。
List<Integer> numbers = Arrays.asList(1, 2, 3, 1, 2, 3);
List<Integer> distinctNumbers = numbers.stream().distinct().collect(Collectors.toList());
System.out.println(distinctNumbers); // 输出 [1, 2, 3]
  • sorted() 对流中的元素进行排序,并返回一个新的流。
List<Integer> numbers = Arrays.asList(3, 1, 4, 1, 5, 9, 2, 6, 5);
List<Integer> sortedNumbers = numbers.stream().sorted().collect(Collectors.toList());
System.out.println(sortedNumbers); // 输出 [1, 1, 2, 3, 4, 5, 5, 6, 9]
  • limit(long maxSize) 截取流中前面的指定数量元素,并返回一个新的流。
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> limitedNumbers = numbers.stream().limit(3).collect(Collectors.toList());
System.out.println(limitedNumbers); // 输出 [1, 2, 3]
  • skip(long n) 跳过流中前面的指定数量元素,并返回一个新的流。
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
List<Integer> skippedNumbers = numbers.stream().skip(2).collect(Collectors.toList());
System.out.println(skippedNumbers); // 输出 [3, 4, 5]
  • forEach(Consumer action) 对流中的每个元素执行指定的操作。
List<String> names = Arrays.asList("Alice", "Bob", "Charlie");
names.stream().forEach(System.out::println);
// 输出
// Alice
// Bob
// Charlie
  • reduce(T identity, BinaryOperator accumulator) 对流中的元素进行累加操作,并返回累加结果。
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
int sum = numbers.stream().reduce(0, (a, b) -> a + b);
System.out.println(sum); // 输出 15
  • collect(Collector<T, A, R> collector) 将流中的元素收集成一个集合或其他数据结构。
List<String> names = Arrays.asList("Alice", "Bob", "Charlie");
String concatenatedNames = names.stream().collect(Collectors.joining(", "));
System.out.println(concatenatedNames); // 输出 "Alice, Bob, Charlie"

使用须知

  1. 需要根据实际情况选择适合的API方法。在使用Java Stream API时,应该根据具体的需求选择适合的API方法。因为Java Stream API提供了很多API方法,不同的API方法适用于不同的场景。
  2. 确定好中间操作和终端操作。Java Stream API中的操作可以分为中间操作和终端操作。中间操作是指可以在Stream中进行链式调用的操作,例如filter()和map()等;终端操作是指对Stream进行终止操作的操作,例如forEach()和collect()等。在使用Java Stream API时,需要确定好中间操作和终端操作,确保Stream能够正常工作。
  3. 避免使用过于复杂的操作。尽管Java Stream API提供了很多API方法,但是过于复杂的操作会影响代码的可读性和可维护性。因此,应该避免使用过于复杂的操作。
  4. 对于大规模数据的处理,建议使用并行流。Java Stream API提供了并行流(parallel stream)的支持,可以将一个Stream分成多个子Stream进行并行处理,提高处理效率。对于大规模数据的处理,建议使用并行流。

文中的APi均为常用型API,具体可以看Stream提供的API与注释。

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

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

相关文章

构建高效PythonWeb:GraphQL+Sanic

1.1 简介&#xff1a;在当今快速发展的技术时代&#xff0c;Web应用的性能和灵活性变得越来越重要。在众多技术中&#xff0c;GraphQL和Sanic以其独特的优势脱颖而出。GraphQL&#xff0c;作为一个强大的数据查询语言&#xff0c;为前端和后端之间的通信提供了极大的灵活性。而…

【现代密码学】笔记2 -- 完善保密性《introduction to modern cryphtography》现代密码学原理与协议

【现代密码学】笔记2--完善保密性《introduction to modern cryphtography》 写在最前面2 完善保密性的介绍2.1 定义和基本属性加密方案的组成密钥产生算法 (Gen)加密算法 (Enc)解密算法 (Dec)概率分布独立性 完美保密加密3. 回顾加密词法4. 完美保密&#xff08;**Perfect Sec…

docker打包介绍

最近在做一个开源项目&#xff0c;遇到开发者问各种问题&#xff0c;发现都是系统和软件版本的差异引起的。于是了解了一下docker的使用&#xff0c;发现docker真是个好东东&#xff0c;基本解决了各种版本差异的问题&#xff0c;真正做到了一键部署使用。 先熟悉一下docker里…

阿里云2核4G服务器ecs.e-c1m2.large价格和性能测评

2024年阿里云2核4G服务器优惠价格30元3个月&#xff0c;活动 https://t.aliyun.com/U/bLynLC 配置为云服务器ECS经济型e实例ecs.e-c1m2.large&#xff0c;3M固定带宽&#xff0c;系统盘为40GB ESSD Entry&#xff0c;活动打开如下图&#xff1a; 阿里云2核4G服务器优惠价格30元…

Python武器库开发-武器库篇之C段扫描器开发(四十三)

Python武器库开发-武器库篇之C段扫描器开发(四十三) 在我们进行渗透过程中的信息收集的步骤时&#xff0c;收集资产目标的C段也是非常重要的一部分。 C段是指互联网中的一类IP地址。IP地址是互联网上每台设备的唯一标识符。IP地址由一系列数字组成&#xff0c;通常以点分十进…

【AI视野·今日Sound 声学论文速览 第四十一期】Thu, 4 Jan 2024

AI视野今日CS.Sound 声学论文速览 Thu, 4 Jan 2024 Totally 8 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Sound Papers Multichannel blind speech source separation with a disjoint constraint source model Authors Jianyu Wang, Shanzheng Guan多通道卷积…

2023 CSIG青年科学家会议丨多模态大模型时代下的文档图像处理

近日&#xff0c;由中国图象图形学学会青年工作委员会发起的“第十九届中国图象图形学学会青年科学家会议”在广州召开。 会议面向国际学术前沿与国家战略需求&#xff0c;聚焦最新前沿技术和热点领域&#xff0c;邀请各界专家与青年学者进行总计超200场的高水平学术深度交流&…

漏洞复现--金蝶云星空反序列化远程代码执行

免责声明&#xff1a; 文章中涉及的漏洞均已修复&#xff0c;敏感信息均已做打码处理&#xff0c;文章仅做经验分享用途&#xff0c;切勿当真&#xff0c;未授权的攻击属于非法行为&#xff01;文章中敏感信息均已做多层打马处理。传播、利用本文章所提供的信息而造成的任何直…

无旋转目标检测labelme的json格式转YOLO

# trans_labelme_to_yolo.pyimport cv2 import os import json import shutil import numpy as np from pathlib import Path from glob import globid2cls =

静态网页设计——千姿百色旅游网(HTML+CSS+JavaScript)(dw、sublime Text、webstorm、HBuilder X)

前言 声明&#xff1a;该文章只是做技术分享&#xff0c;若侵权请联系我删除。&#xff01;&#xff01; 感谢大佬的视频&#xff1a; https://www.bilibili.com/video/BV1oe411m7kH/?vd_source5f425e0074a7f92921f53ab87712357b 源码&#xff1a;https://space.bilibili.co…

获取每一个目录下面文件的个数并删除文件少于一定数据的目录( 源码)

import os import shutil # 假设 directory_A 是目录A的路径 directory_A /home/unitree/newHardDisk/VINT_data_train/go_stanford/# 遍历目录A中的每个子目录&#xff0c;并计算每个子目录中的文件数量 def count_files_in_subdirectories(directory):# 存储每个子目录文件数…

啊哈c语言——5.9逻辑挑战11(猜数游戏)

计算机会随机地给出0&#xff5e;99之间的一个整数&#xff0c;你能否猜出这个数呢&#xff1f;每猜一次&#xff0c;计算机都会告诉你猜的数是大了还是小了&#xff0c;直到你猜出这个数为止。 首先我们需要解决的第一个问题就是如何让计算机随机地产生一个整数&#xff0c;这…

云水苍苍走四方

云水苍苍走四方 &#xff08;一&#xff09;燕赵行 庚午年秋&#xff0c;内师大前旗理论班同学挚友四十余人&#xff0c;东行三千里&#xff0c;饱览燕赵风光。往事虽逝&#xff0c;记忆犹在&#xff0c;故追记之。 谒雪芹故居 这是一个红叶醉人&#xff0c;鸣蝉送幽的晚秋。我…

vue-springboot基于java的实验室安全考试系统

本系统为用户而设计制作实验室安全考试系统&#xff0c;旨在实现实验室安全考试智能化、现代化管理。本实验室安全考试管理自动化系统的开发和研制的最终目的是将实验室安全考试的运作模式从手工记录数据转变为网络信息查询管理&#xff0c;从而为现代管理人员的使用提供更多的…

1- forecasting at scale论文阅读

目录 1. 什么是时间序列2. 什么是时间序列预测3. 时间序列预测的范式4. 时间序列的专有名词介绍5. 时间序列评估 1. 什么是时间序列 按时间先后顺序出现的有序序列 2. 什么是时间序列预测 点预测&#xff1a;预测未来的某一个时间点&#xff0c;它的值到底是多少&#xff0c…

搭建宠物寄养小程序流程

近日&#xff0c;一地宠物寄养需求旺盛&#xff0c;元旦满房&#xff0c;春节几近饱和&#xff0c;一窝难求。随着市场需求的增长&#xff0c;对于很多宠物行业的商家&#xff0c;可以考虑开展宠物寄养服务&#xff0c;尤其是节假日的宠物寄养需求会更高。因此&#xff0c;商家…

我是内网灵活的狗之stack靶场1

首先我们还是老样子 我们先启动这个在win7上面的php工具&#xff0c;也就是启动php服务 然后我们启动kali攻击机 然后打开webshell工具 然后我们先打开MSF工具进行监听 启动msf工具进行监听 12345端口 然后在文件中打开虚拟终端&#xff0c;连接到目标机器内部 start 620.exe…

PyTorch的核心模块介绍

PyTorch的核心模块介绍 1. torch 模块2. torch.Tensor 模块3. torch.nn 模块4. torch.optim 模块5. torch.jit 模块6. torch.onnx 模块7. torch.utils 模块8. torch.autograd模块9.其他模块 1. torch 模块 包含常用的常量、函数和类等。常用函数&#xff1a; torch.add &#…

加密世界危机四伏,普通用户该如何应对钓鱼陷阱

据区块链安全公司 Scam Sniffer 称&#xff0c;加密货币网络钓鱼活动在 2023 年有所增加&#xff0c;诈骗者利用钱包盗取恶意软件从受害者那里窃取了近 3 亿美元。金额很惊人是不是&#xff1f;只是没想到素以小心谨慎为口号冲浪的我也栽了一回。还原一下事情经过&#xff1a; …

免费ai编程助手,赶紧用起来

阿里搞了个通义灵码&#xff0c;免费的ai变成助手&#xff0c;可以方便集成到vscode中。赶紧用起来&#xff0c;已经给很多人推荐过了&#xff0c; 效果还是非常不错的。 搭配着通义千问来用效果更好了。近期钉钉推出的那个个人版钉钉也是集成了各种ai工具&#xff0c;感觉还是…