Java 1.8 Stream 流 Reduce 规约合并
一则或许对你有用的小广告
欢迎加入小哈的星球 ,你将获得:专属的项目实战 / 1v1 提问 / Java 学习路线 / 学习打卡 / 每月赠书 / 社群讨论
- 新项目:《从零手撸:仿小红书(微服务架构)》 正在持续爆肝中,基于
Spring Cloud Alibaba + Spring Boot 3.x + JDK 17...
,点击查看项目介绍 - 《从零手撸:前后端分离博客项目(全栈开发)》 2 期已完结,演示链接: http://116.62.199.48/
截止目前, 星球 内专栏累计输出 66w+ 字,讲解图 2896+ 张,还在持续爆肝中.. 后续还会上新更多项目,目标是将 Java 领域典型的项目都整一波,如秒杀系统, 在线商城, IM 即时通讯,权限管理,Spring Cloud Alibaba 微服务等等,已有 2300+ 小伙伴加入学习 ,欢迎点击围观
在 Java 1.8 中,Stream API 提供了 reduce()
方法用于将流中的元素进行归约操作。reduce()
方法允许我们根据指定的操作,将流中的元素合并为一个结果。
本教程将深入介绍 Java 1.8 中的 Stream 的 reduce()
方法,并通过示例代码演示如何使用它。
reduce() 方法概览
在 Stream API 中,reduce()
方法用于将流中的元素进行归约操作。
Optional<T> reduce(BinaryOperator<T> accumulator)
T reduce(T identity, BinaryOperator<T> accumulator)
<U> U reduce(U identity, BiFunction<U, ? super T, U> accumulator, BinaryOperator<U> combiner)
reduce(BinaryOperator<T> accumulator)
方法对流中的元素进行归约操作,并返回一个Optional<T>
类型的结果。reduce(T identity, BinaryOperator<T> accumulator)
方法对流中的元素进行归约操作,并返回一个T
类型的结果。identity
是一个初始值,用于在流为空时返回。reduce(U identity, BiFunction<U, ? super T, U> accumulator, BinaryOperator<U> combiner)
方法用于并行流的归约操作。identity
是一个初始值,combiner
用于合并并行计算的结果。
使用 reduce() 方法
让我们通过几个示例来说明如何使用 reduce()
方法。
示例 1:计算整数列表的总和
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
// 使用 reduce() 方法计算整数列表的总和
Optional<Integer> sum = numbers.stream()
.reduce((a, b) -> a + b);
if (sum.isPresent()) {
System.out.println("Sum of numbers: " + sum.get()); // 输出 "Sum of numbers: 15"
}
在这个例子中,我们首先创建一个整数列表 numbers
。然后,我们使用 stream()
方法将列表转换为 Stream 对象,再使用 reduce()
方法对整数列表进行归约操作,将所有元素相加并得到一个 Optional<Integer>
类型的结果。
示例 2:计算整数列表的乘积
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
// 使用 reduce() 方法计算整数列表的乘积
int product = numbers.stream()
.reduce(1, (a, b) -> a * b);
System.out.println("Product of numbers: " + product); // 输出 "Product of numbers: 120"
在这个例子中,我们使用 stream()
方法将列表转换为 Stream 对象,再使用 reduce()
方法对整数列表进行归约操作,将所有元素相乘并得到一个 int
类型的结果。注意,在这个示例中我们使用了初始值 1
,用于在流为空时返回。
示例 3:使用并行流计算整数列表的总和
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5);
// 使用并行流和 reduce() 方法计算整数列表的总和
int sum = numbers.parallelStream()
.reduce(0, (a, b) -> a + b, Integer::sum);
System.out.println("Sum of numbers with parallel stream: " + sum); // 输出 "Sum of numbers with parallel stream: 15"
在这个例子中,我们使用 parallelStream()
方法将列表转换为并行流,再使用 reduce()
方法对整数列表进行归约操作,并使用 Integer::sum
作为合并函数 combiner
,将并行计算的结果合并。
总结
Java 1.8 中的 Stream API 提供了 reduce()
方法,用于将流中的元素进行归约操作。通过使用 reduce()
方法,你可以根据指定的操作将流中的元素合并为一个结果。