Collectors.partitioningBy返回Map,根据条件将流中元素分为两组,键true表示满足条件的元素列表,false表示不满足的。如按奇偶分区整数,或统计大于某值的数量,还可结合下游收集器去重或聚合,使用简洁高效。

在Java中,Collectors.partitioningBy 是一个用于将集合元素按照某个条件划分为两个区组的收集器。它返回一个 Map<boolean list>></boolean>,其中键为 true 和 false,分别对应满足和不满足条件的元素列表。
Collectors.partitioningBy(Predicate super T> predicate) 接收一个谓词(Predicate),根据该条件对流中的元素进行分区。
常见应用场景包括:将数字分为奇偶、对象按状态分类、数值是否大于某个阈值等。
示例:将整数列表按是否为偶数分区
import java.util.*;
import java.util.stream.Collectors;
List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8);
Map<Boolean, List<Integer>> partitioned = numbers.stream()
.collect(Collectors.partitioningBy(n -> n % 2 == 0));
System.out.println("偶数: " + partitioned.get(true)); // [2, 4, 6, 8]
System.out.println("奇数: " + partitioned.get(false)); // [1, 3, 5, 7]
你可以通过 partitioningBy(Predicate, Collector) 指定下游收集器,对分区后的数据进一步处理,比如转为Set、统计数量、求和等。
立即学习“Java免费学习笔记(深入)”;
示例:统计每个分区的数量
Map<Boolean, Long> counts = numbers.stream()
.collect(Collectors.partitioningBy(
n -> n > 5,
Collectors.counting()
));
System.out.println("大于5的个数: " + counts.get(true)); // 3
System.out.println("不大于5的个数: " + counts.get(false)); // 5
如果原始数据可能有重复,可以这样去重:
Map<Boolean, Set<Integer>> uniquePartition = numbersWithDuplicates.stream()
.collect(Collectors.partitioningBy(
n -> n % 2 == 0,
Collectors.toSet()
));
partitioningBy 比 groupingBy 更直观高效。true 和 false,即使某一分区为空。Collectors.mapping() 可实现更复杂的转换逻辑。Collectors.partitioningBy 能让条件分组代码更简洁清晰。以上就是Java里如何使用Collectors.partitioningBy对集合分区_集合分区操作方法说明的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号