登录
首页 >  文章 >  java教程

JavaCollectors.partitioningBy分区用法详解

时间:2026-02-13 23:49:44 392浏览 收藏

Java 8 Stream API 中的 Collectors.partitioningBy 是一个高效简洁的分区工具,能根据布尔条件(如判断奇偶、是否成年等)将数据流一分为二,直接返回以 true/false 为键、对应元素列表为值的 Map,不仅语义清晰、代码简练,还支持嵌套下游收集器实现更复杂的聚合操作,是处理二元分类场景的首选方案。

Java中如何利用Collectors.partitioningBy进行数据分区

在Java 8引入的Stream API中,Collectors.partitioningBy 是一个非常实用的收集器,它可以根据一个布尔条件将数据分成两个分区:一个是满足条件的元素,另一个是不满足条件的元素。返回结果是一个 Map>,其中键为 truefalse,分别对应匹配和不匹配的元素列表。

基本语法

partitioningBy 接收一个 Predicate(谓词)函数式接口作为参数:

Collector>> partitioningBy(Predicate predicate)

简单示例:按偶数奇数分区

假设我们有一个整数列表,想把偶数和奇数分开:

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

List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

Map<Boolean, List<Integer>> evenOddPartition = numbers.stream()
    .collect(Collectors.partitioningBy(n -> n % 2 == 0));

System.out.println("偶数: " + evenOddPartition.get(true));
System.out.println("奇数: " + evenOddPartition.get(false));
输出结果:

偶数: [2, 4, 6, 8, 10]
奇数: [1, 3, 5, 7, 9]

复杂对象的分区示例:按年龄是否成年

我们有一个用户类,想根据是否成年(年龄 ≥ 18)进行分区:

class Person {
    String name;
    int age;

    Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    // getter 方法
    public String getName() { return name; }
    public int getAge() { return age; }

    @Override
    public String toString() {
        return name + "(" + age + ")";
    }
}

List<Person> people = Arrays.asList(
    new Person("Alice", 25),
    new Person("Bob", 17),
    new Person("Charlie", 20),
    new Person("Diana", 16)
);

Map<Boolean, List<Person>> adultMinor = people.stream()
    .collect(Collectors.partitioningBy(p -> p.getAge() >= 18));

System.out.println("成年人: " + adultMinor.get(true));
System.out.println("未成年人: " + adultMinor.get(false));
输出:

成年人: [Alice(25), Charlie(20)]
未成年人: [Bob(17), Diana(16)]

进阶用法:结合 downstream 收集器

你还可以使用 partitioningBy 的重载方法,传入第二个收集器来进一步处理每个分区的数据。

例如,只统计每组人数:

Map<Boolean, Long> countByAdult = people.stream()
    .collect(Collectors.partitioningBy(
        p -> p.getAge() >= 18,
        Collectors.counting()
    ));

System.out.println("成年人数: " + countByAdult.get(true)); // 2
System.out.println("未成年数: " + countByAdult.get(false)); // 2
或者提取名字列表:

Map<Boolean, List<String>> namesByAgeGroup = people.stream()
    .collect(Collectors.partitioningBy(
        p -> p.getAge() >= 18,
        Collectors.mapping(Person::getName, Collectors.toList())
    ));
基本上就这些。partitioningBy 特别适合二元分类场景,代码清晰且表达力强,是Stream中处理“是/否”类分组的首选方式。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《JavaCollectors.partitioningBy分区用法详解》文章吧,也可关注golang学习网公众号了解相关技术文章。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>