本文介绍如何使用 Java Stream API 将数据流按照特定条件进行分区,并将分区后的数据分别收集到不同的集合中。通过 Collectors.partitioningBy 方法,可以高效地将数据流划分为满足条件和不满足条件的两部分,从而避免使用传统的循环方式,简化代码并提高可读性。
Java Stream API 提供了 Collectors.partitioningBy 方法,可以根据给定的 Predicate(断言)将数据流划分为两个集合:一个集合包含所有满足 Predicate 的元素,另一个集合包含所有不满足 Predicate 的元素。
partitioningBy 方法返回一个 Map
示例代码:
立即学习“Java免费学习笔记(深入)”;
假设我们有一个 ID 列表 myIdList 和一个将 ID 映射到对象的 Map myObjectMap。我们的目标是根据 ID 是否存在于 myObjectMap 中,将 ID 分成两组:存在于 myObjectMap 中的 ID 对应的对象放入一个 List,不存在于 myObjectMap 中的 ID 放入另一个 List。
import java.util.*; import java.util.stream.Collectors; public class StreamPartitioning { public static void main(String[] args) { List<String> myIdList = Arrays.asList("a", "b", "c"); Map<String, Object> myObjectMap = new HashMap<>(); myObjectMap.put("b", "B"); Map<Boolean, List<String>> partitioned = myIdList.stream() .collect(Collectors.partitioningBy(myObjectMap::containsKey)); List<Object> objectList = partitioned.get(true).stream() .map(myObjectMap::get) .collect(Collectors.toList()); List<String> missingObjIds = partitioned.get(false); System.out.println("objectList=" + objectList); System.out.println("missingObjIds=" + missingObjIds); } }
代码解释:
输出结果:
objectList=[B] missingObjIds=[a, c]
Collectors.partitioningBy 方法是 Java Stream API 中一个强大的工具,可以用于将数据流按照特定条件进行分区,并将分区后的数据分别收集到不同的集合中。通过使用 partitioningBy 方法,可以简化代码并提高可读性。然而,需要注意的是,partitioningBy 方法可能会影响性能,因此在处理大型数据流时需要谨慎使用。
以上就是使用 Java Stream API 分区数据流并获取不同的集合的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号