Java里如何使用Collectors.partitioningBy对集合分区_集合分区操作方法说明

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

在Java中,Collectors.partitioningBy 是一个用于将集合元素按照某个条件划分为两个区组的收集器。它返回一个 Map>,其中键为 truefalse,分别对应满足和不满足条件的元素列表。

基本语法与使用方式

Collectors.partitioningBy(Predicate super T> predicate) 接收一个谓词(Predicate),根据该条件对流中的元素进行分区。

常见应用场景包括:将数字分为奇偶、对象按状态分类、数值是否大于某个阈值等。

示例:将整数列表按是否为偶数分区

import java.util.*;
import java.util.stream.Collectors;

List numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8);

Map> partitioned = numbers.stream()
    .collect(Collectors.partitioningBy(n -> n % 2 == 0));

System.out.println("偶数: " + parti

tioned.get(true)); // [2, 4, 6, 8] System.out.println("奇数: " + partitioned.get(false)); // [1, 3, 5, 7]

结合下游收集器进行聚合操作

你可以通过 partitioningBy(Predicate, Collector) 指定下游收集器,对分区后的数据进一步处理,比如转为Set、统计数量、求和等。

示例:统计每个分区的数量

Map 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

示例:将分区结果收集为Set避免重复

如果原始数据可能有重复,可以这样去重:

Map> uniquePartition = numbersWithDuplicates.stream()
    .collect(Collectors.partitioningBy(
        n -> n % 2 == 0,
        Collectors.toSet()
    ));

实际应用建议

  • 当只需要将数据分为“是”和“否”两类时,partitioningBygroupingBy 更直观高效。
  • 注意返回的Map始终包含两个键:truefalse,即使某一分区为空。
  • 可用于过滤并保留两组数据,避免多次遍历集合。
  • 结合 Collectors.mapping() 可实现更复杂的转换逻辑。
基本上就这些。合理使用 Collectors.partitioningBy 能让条件分组代码更简洁清晰。