8个实用的Java Streams API

java,streams,api · 浏览次数 : 0

小编点评

归纳总结: 本文分享了 8 个开箱即用的 API,分别为: 1. 过滤空值:Stream.ofNullable 2. 流式迭代:Stream.iterate() 3. 集合转换:collectingAndThen() 4. 删除和截取:dropWhile()、takeWhile() 5. 整数流:IntStream 6. 应用多个收集器:teeing() 7. 合并流:Stream.concat() 8. 分组:Collectors.partitioningBy() 这些 API 可以提高日常数据处理效率并减少潜在的错误。文中还提供了一个简单示例以解释如何使用这些 API。

正文

分享8个开箱即用的API,方便日常处理集合。

1. 快速过滤空值:Stream.ofNullable

该方法是在 Java 9 中引入的,有助于过滤集合中的所有空值,从而可能使我们避免空指针异常。

在下面的示例中,有一个包含 null 的List。此时,我们可以使用Stream.ofNullable方法对其进行过滤。

List<String> names = Arrays.asList("Alice", null, "Bob", null, "Charlie");
List<String> nonNuLLNames = names.stream()
    .flatMap(Stream::ofNullable)
    .collect(Collectors.toList());
System.out.println(nonNuLLNames);

执行上述代码,将输出:

[Alice, Bob, Charlie]

2. 流式迭代:Stream.iterate()

Stream.iterate()方法用于创建无限的序列流。它采用种子和一元函数,将函数应用于前一个元素。

在下面的例子中,我们的种子是0,一元运算函数是 n -> n+2。

Stream.iterate(seed: 0, n -> n+2)
    .Limit( maxsize: 10)
    .forEach(e-> {
        System,out printin(e)
    });

执行上述代码,将输出:

0
2
4
6
8
10
12
14
16
18

注意:由于Stream.iterate()生成的是无限序列流。因此我们应该定义终止条件,例如:limit、findFirst 或 findAny 等,以避免无限循环。

3. 集合转换:collectingAndThen()

collectingAndThen()方法是在 Java 8 中引入的。它是一种特殊的收集器,允许您对另一个收集器的结果执行特殊类型的转换。

在下面的示例中,我们的收集器通过首先使用索引到大写操作进行映射,然后使该映射成为不可修改的Map进行转换。

List<String> fruits = Arrays.asList("apple", "banana","orange");
Map<Integer, String> result = fruits.stream()
  .collect(Collectors.collectingAndThen(
    Collectors.toMap(fruits::index0f,String::toUpperCase),
    Collections::unmodifiableMap
  ));
System.out.println(result)

执行上述代码,将输出:

{0=APPLE, 1=BANANA, 2=ORANGE}

4. 删除和截取:dropWhile()takeWhile()

dropWhile()takeWhile()方法是在 java9 中引入的,用于连续处理流。

  • takeWhile():返回符合条件的元素流
  • dropWhile():从元素流中删除符合条件的元素

在下面的示例中,我们删除小于3的元素,然后返回元素小于6的元素流。

List<Integer> numbers = List.of(1,2,3,4,5,6,7);
numbers.stream()
  .dropWhile(n -> n < 3)
  .takeWhile(n -> n < 6)
  .forEach(System.out::println);

执行上述代码,将输出:

3
4
5

5. 整数流:IntStream

IntStream 在 Java 8 中引入,用于快速生成整数流,常用有的以下两个方法:

  • IntStream.range() 方法生成一个整数流,该整数流不包含结尾数字
  • IntStream.rangeClosed() 方法生成一个整数流,该整数流包含结尾数字

下面的例子,可以清晰的看到区别:

// Prints 1,2,3,4
IntStream.range(1,5).forEach(System.out::println); 
// Prints 1,2,3,4,5
IntStream.rangeClosed(1,5).forEach(System.out::println); 

6. 应用多个收集器:teeing()

Java 12 中引入的teeing()方法是为了我们可以在元素流上一起应用两个单独的收集器而创建的。

在下面的示例中,我们使用teeing()计算元素流的最大值和最小值,然后将结果以Map形式返回。

Stream<Integer> nums = Stream.of( ...values: 1 2,3 4);
Map<String, Integer> collect = nums.collect(Collectors.teeing(
  ColLectors.maxBy(Integer::compareTo),
  CoLlectors.minBy(Integer::compareTo),
  (e1, e2) -> Map.of( k1: "min", e1.get(), k2: "max", e2.get())
));

System.out.println(collect);

执行上述代码,将输出:

{max=1, min=4}

7. 合并流:Stream.concat()

Stream.concat()方法可以用来连接两个流并生成一个新流。

Stream<Integer> stream1 = Stream.of(...values: 1,2,3);
Stream<Integer> stream2 = Stream.of(...values: 4,5,6);
Stream.concat(stream1, stream2)
  .forEach(System.out::println);

执行上述代码,将输出:

1
2
3
4
5
6

8. 分组:Collectors.partitioningBy

Collectors.partitioningBy可以用来对流进行分组。

在下面的示例中,我们根据元素的字符串长度分为两个不同的组。

Map<Boolean, List<String>> result1 = Stream.of(...values: "apple", "banana", "orange", "grape")
  .collect(Collectors.partitioningBy(f -> f.length() > 5));

System.out.println(result1);

执行上述代码,将输出:

{false=[apple, grape], true=[banana, orange]}

今天的分享就到这里。如果您学习过程中如遇困难?可以加入我们超高质量的技术交流群,参与交流与讨论,更好的学习与进步

欢迎关注我的公众号:程序猿DD。第一时间了解前沿行业消息、分享深度技术干货、获取优质学习资源

与8个实用的Java Streams API相似的内容:

8个实用的Java Streams API

分享8个开箱即用的API,方便日常处理集合。 1. 快速过滤空值:Stream.ofNullable 该方法是在 Java 9 中引入的,有助于过滤集合中的所有空值,从而可能使我们避免空指针异常。 在下面的示例中,有一个包含 null 的List。此时,我们可以使用Stream.ofNullable

Go应用性能优化的8个最佳实践,快速提升资源利用效率!

> 作者|Ifedayo Adesiyan > 翻译|Seal软件 > 链接|https://earthly.dev/blog/optimize-golang-for-kubernetes/ 优化服务器负载对于确保运行在 Kubernetes 上的 Golang 应用程序的高性能和可扩展性至关重要。

8个云成本优化的最佳实践

在《2022年云计算现状报告》中,国际知名软件资产管理商 Flexera 通过对近千家企业进行调查得出数据:企业平均浪费32%的云业务支出。随后,在2023年的报告中,FinOps 12年来首次超越安全,成为诸多企业关注的头等大事。 本文我们将展开聊聊企业乃至开发人员如何进行云成本优化。 1、设置指

基于WebSocket的modbus通信(二)- 客户端

上一篇已经实现了ModbusTcp服务器和8个主要的功能码,只是还没有实现错误处理功能。 但是在测试客户端时却发现了上一篇的一个错误,那就是写数据成功,服务器不需要响应。 接下来要做的就是实现ModbusTcp客户端。有了清晰的协议,代码循规蹈矩的写就行了。 效果 原始数据 其中只读寄存器和线圈都有

6个实例带你解读TinyVue 组件库跨框架技术

本文分享自华为云社区《6个实例带你解读TinyVue 组件库跨框架技术》,作者: 华为云社区精选。 在DTSE Tech Talk 《 手把手教你实现mini版TinyVue组件库 》的主题直播中,华为云前端开发DTSE技术布道师阿健老师给开发者们展开了组件库跨框架的讨论,同时针对TinyVue组件

SpringBoot 整合 EasyExcel 实现自由导入导出,太强了

在实际的业务系统开发过程中,操作 Excel 实现数据的导入导出基本上是个非常常见的需求。 之前,我们有介绍一款非常好用的工具:EasyPoi,有读者提出在数据量大的情况下,EasyPoi 会占用内存大,性能不够好,严重的时候,还会出现内存异常的现象。 今天我给大家推荐一款性能更好的 Excel 导

C# 8.0 中的 Disposable ref structs(可处置的 ref 结构)

由于官方文档没有示例用法,开始一直看着摸不着头脑,因此在网上找了个实例,以供参考,希望有助于你我的理解。

Dubbo3应用开发—Dubbo注册中心引言

Dubbo注册中心引言 什么是Dubbo注册中心 Dubbo的注册中心,是Dubbo服务治理的⼀个重要的概念,他主要用于 RPC服务集群实例的管理。 注册中心的运行流程 使用注册中心的好处 可以有效的管理RPC集群的健康情况,动态的上线或者下线服务。让我们的服务更加高可用。 Provider与Con

【matplotlib 实战】--直方图

直方图,又称质量分布图,用于表示数据的分布情况,是一种常见的统计图表。 一般用横轴表示数据区间,纵轴表示分布情况,柱子越高,则落在该区间的数量越大。构建直方图时,首先首先就是对数据划分区间,通俗的说即是划定有几根柱子(比如,1980年~2020年的数据,每5年划分一个区间的话,共8个区间)。接着,对

实战 k8s----初识

什么是k8s?k8s是谷歌开源的一套完整的容器管理平台,方便我们直接管理容器应用。谷歌称之为,kubernetes,[kubə’netis] ,(跟我一起读库波尔耐题思,重音在耐的音上),由于字母太多,我们简称为k8s,8代表k-->s之间的8个字母。kubernetes 译为舵手,标识是一个航海舵