Java函数式编程【三】【Stream终止操作】【上】之【简单约简】

函数式编程可分为三个步骤:流的创建、流的中间操作和流的终止操作。其中流的中间操作可以有n个,而流的终止操作只能有一个。

函数式编程三个步骤示意图:

常用的终止操作

Stream的终止操作大致可分为两大类:简单约简的终止操作和复杂终止操作。

(一)、八个常用的简单约简终止操作

  • allMatch、anyMatch、noneMatch 匹配操作,数据流中是否存在符合条件的元素 返回值为boolean值。
  • count 统计操作,统计最终的数据个数。
  • findFirst、findAny 查找操作,查找第一个、查找任何一个 返回的类型为Optional。
  • min、max 最值操作,需要自定义比较器,返回数据流中最大最小的值。

简单约简的返回结果是要么是boolean,要么是Optional类型。

(二)、复杂的终止操作

  • forEach、forEachOrdered 遍历操作,这两个操作都是对Stream中的数据元素进行消费操作。
  • collect 收集操作,将所有数据收集起来,这个操作非常重要,官方的提供的Collectors 提供了非常多收集器,可以说终止操作collect是Stream的终极大杀器。
  • reduce 归约操作,将整个Stream中的数据元素归约为一个值,例如:count、min、max底层就是使用reduce实现的。
  • toArray 数组操作,将Stream中的数据元素存放到数组中。

终止操作的使用示例

1,匹配操作(allMatch、anyMatch、noneMatch)Stream也支持类似集合匹配元素的操作,匹配返回的结果是boolean类型。

anyMatch(Predicate), allMatch(Predicate), 和 noneMatch(Predicate): 检查流中是否有符合给定条件的元素、是否所有元素都符合条件、是否没有元素符合条件。

cpp 复制代码
List<Integer> list = Arrays.asList(7, 6, 9, 3, 2, 15);
boolean anyMatch = list.stream().anyMatch(x -> x < 6);
boolean allMatch = list.stream().allMatch(x -> x < 6);
boolean noneMatch = list.stream().noneMatch(x -> x < 6);

2,统计操作 count(): 统计流中元素的数量。

cpp 复制代码
	long count = Stream.of("Alice", "Bob", "Charlie").count();

3,计算最大和最小值:max(Comparator) 和 min(Comparator): 根据比较器返回流中的最大或最小元素。

cpp 复制代码
		Optional<String> maxName = Stream.of("Alice", "Bob", "Charlie").max(Comparator.naturalOrder());
        System.out.println("最长的名字:" + maxName.get());
        List<String> sList = Arrays.asList("World", "me", "you");
		Optional<String> min = sList.stream().min(Comparator.comparing(String::length));
		System.out.println("最短的字符串:" + min.get());
		Optional<String> max = sList.stream().max(Comparator.comparing(String::length));
		System.out.println("最长的字符串:" + max.get());

4,查找操作:(findFirst/findAny)查找第一个、查找任何一个 返回的类型为Optional。

cpp 复制代码
        List<Integer> list = Arrays.asList(7, 6, 9, 3, 2, 15);
        // 匹配第一个
        Optional<Integer> findFirst = list.stream().filter(x -> x > 6).findFirst();
        // 匹配任意(适用于并行流)
        Optional<Integer> findAny = list.parallelStream().filter(x -> x > 6).findAny();
        System.out.println("匹配第一个值:" + findFirst.get());
        System.out.println("匹配任意一个值:" + findAny.get());  

5,遍历操作( forEach)

终止操作 forEach的方法签名(原型),它的输入参数是一个类型为消费者接口的函数接口:

cpp 复制代码
	void java.util.stream.Stream.forEach(Consumer<? super Integer> action)

下面是一个查找操作和遍历操作的示例:

cpp 复制代码
        List<Integer> list = Arrays.asList(7, 6, 9, 3, 2, 15);
        // 遍历输出符合条件的元素
        list.stream().filter(x -> x > 6).forEach(System.out::println);

参考文献:

相关推荐
Swift社区10 分钟前
从 JDK 1.8 切换到 JDK 21 时遇到 NoProviderFoundException 该如何解决?
java·开发语言
DKPT1 小时前
JVM中如何调优新生代和老生代?
java·jvm·笔记·学习·spring
phltxy1 小时前
JVM——Java虚拟机学习
java·jvm·学习
seabirdssss3 小时前
使用Spring Boot DevTools快速重启功能
java·spring boot·后端
喂完待续3 小时前
【序列晋升】29 Spring Cloud Task 微服务架构下的轻量级任务调度框架
java·spring·spring cloud·云原生·架构·big data·序列晋升
benben0443 小时前
ReAct模式解读
java·ai
轮到我狗叫了3 小时前
牛客.小红的子串牛客.kotori和抽卡牛客.循环汉诺塔牛客.ruby和薯条
java·开发语言·算法
Volunteer Technology5 小时前
三高项目-缓存设计
java·spring·缓存·高并发·高可用·高数据量
栗子~~5 小时前
bat脚本- 将jar 包批量安装到 Maven 本地仓库
java·maven·jar