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

在Java中,Collectors.partitioningBy 是一个用于将集合元素按照某个条件划分为两个区组的收集器。它返回一个 Map,其中键为 true 和 false,分别对应满足和不满足条件的元素列表。
基本语法与使用方式
Collectors.partitioningBy(Predicate super T> predicate) 接收一个谓词(Predicate),根据该条件对流中的元素进行分区。
常见应用场景包括:将数字分为奇偶、对象按状态分类、数值是否大于某个阈值等。
示例:将整数列表按是否为偶数分区
import java.util.*; import java.util.stream.Collectors; Listnumbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8); Map > 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示例:将分区结果收集为Set避免重复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> uniquePartition = numbersWithDuplicates.stream() .collect(Collectors.partitioningBy( n -> n % 2 == 0, Collectors.toSet() ));
实际应用建议
- 当只需要将数据分为“是”和“否”两类时,
partitioningBy比groupingBy更直观高效。 - 注意返回的Map始终包含两个键:
true和false,即使某一分区为空。 - 可用于过滤并保留两组数据,避免多次遍历集合。
- 结合
Collectors.mapping()可实现更复杂的转换逻辑。
Collectors.partitioningBy 能让条件分组代码更简洁清晰。










