分享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的更多相关文章

  1. [转]深入理解Java 8 Lambda(类库篇——Streams API,Collectors和并行)

    以下内容转自: 作者:Lucida 微博:@peng_gong 豆瓣:@figure9 原文链接:http://zh.lucida.me/blog/java-8-lambdas-insideout-l ...

  2. 深入理解Java 8 Lambda(类库篇——Streams API,Collectors和并行)

    转载:http://zh.lucida.me/blog/java-8-lambdas-inside-out-library-features/ 关于 深入理解 Java 8 Lambda(语言篇——l ...

  3. Java 9 揭秘(18. Streams API 更新)

    Tips 做一个终身学习的人. 在本章中,主要介绍以下内容: 在Stream接口中添加了更加便利的方法来处理流 在Collectors类中添加了新的收集器(collectors) JDK 9中,在St ...

  4. Java 8 Streams API 详解

    流式编程作为Java 8的亮点之一,是继Java 5之后对集合的再一次升级,可以说Java 8几大特性中,Streams API 是作为Java 函数式的主角来设计的,夸张的说,有了Streams A ...

  5. Lambda类库篇 —— Streams API, Collector和并行

    本文是深入理解Java 8 Lambda系列的第二篇,主要介绍Java 8针对新增语言特性而新增的类库(例如Streams API.Collectors和并行). 本文是对 Brian Goetz 的 ...

  6. JAVA PERSISTENCE API (JPA)

    13.2.1. About JPA The Java Persistence API (JPA) is the standard for using persistence in Java proje ...

  7. Eclipse Collections:让Java Streams更上一层楼

    \ 关键要点 \\ Eclipse Collections是一个高性能的Java集合框架,为原生JDK集合增加了丰富的功能.\\t Streams是JDK的一个非常受欢迎的功能,但它缺少了一些特性,严 ...

  8. Java 常用API(二)

    目录 Java 常用API(二) 1. Object类 2. Date类 概述 构造方法和成员方法 3. DateFormat类 概述 SimpleDateFormat类 练习 4. Calendar ...

  9. 关于c#调用java中间件api的几个问题

    由于项目需要,做的c#客户端数据库连接串首先肯定不能写死的程序里(数据库很容易被攻击,我们的项目半年改了几次密码...) 放置在配置文件内,都可以看得到,最开始想法将配置文件加密,老师说加密过的文件还 ...

  10. Kylin Java RESTful API

    最近在做大数据方面的开发, 学习研究了一段时间的kylin系统, 对于前端开发需要使用 RESTful API ,但是官网并没有提供详细的Java  API. 经过几天的看文档,最终写出了 Java ...

随机推荐

  1. Pytorch-tensor的创建,索引,切片

    1.基本概念 标量:就是一个数,是0维的,只有大小,没有方向 向量:是1*n的一列数,是1维的,有大小,也有方向 张量:是n*n的一堆数,是2维的,n个向量合并而成 2.a.size(),a.shap ...

  2. Flutter笔记 - 布局类组件

    布局类组件 Row水平方向排列 textDirection 水平方向子组件布局顺序. mainAxisSize 占用空间,默认MainAxisSize.MAX mainAxisAligment 对齐方 ...

  3. HL7消息类型

    HL7消息有很多不同的类型,每种都有其自己的独特用途和消息内容.以下是常见的HL7消息类型的列表. Message Type Description HL7 ADT Admit, Discharge ...

  4. 力扣578(MySQL)-查询回答率最高的问题(中等)

    题目: 从 survey_log 表中获得回答率最高的问题,survey_log 表包含这些列:id, action, question_id, answer_id, q_num, timestamp ...

  5. HarmonyOS NEXT应用开发—翻页动效案例

    介绍 翻页动效是应用开发中常见的动效场景,常见的有书籍翻页,日历翻页等.本例将介绍如何通过ArkUI提供的显示动画接口animateTo实现翻页的效果. 效果图预览 使用说明 本例通过setInter ...

  6. 全链路灰度之 RocketMQ 灰度

    ​简介:本文将以上次介绍过的<如何用 20 分钟就能获得同款企业级全链路灰度能力?>中的场景为基础,来进一步介绍消息场景的全链路灰度. 作者:亦盏 之前的系列文章中,我们已经通过全链路金丝 ...

  7. Flink 最佳实践之使用 Canal 同步 MySQL 数据至 TiDB

    简介: 本文将介绍如何将 MySQL 中的数据,通过 Binlog + Canal 的形式导入到 Kafka 中,继而被 Flink 消费的案例. 一. 背景介绍 本文将介绍如何将 MySQL 中的数 ...

  8. 云原生消息、事件、流超融合平台——RocketMQ 5.0 初探

    简介: 今天分享的主题是云原生消息事件流超融合平台 RocketMQ 5.0 初探,内容主要分为三个部分: 首先,带大家回顾业务消息领域首选 RocketMQ 4 发展历史以及 4.x 版本的演进与发 ...

  9. [GPT] jquery chosen插件选择的多个元素是逗号分隔的,怎么设置成其它分隔符号 ?

    如果你想要在 jQuery Chosen 插件中使用其它分隔符号,可以通过以下方式实现: 1. 设置 delimiter 选项为一个包含所需分隔符的字符串. $(".chosen-selec ...

  10. 基于EPCLYPSE的DDS控制器(一)

    软硬件平台 操作系统:windows11 软件平台:vivado2021.1 开发套件 硬件平台:Digilent Eclypse-Z7 Zmod开发套件 vivado 工程搭建 ①直接拉取笔者的三个 ...