本文介绍使用 java 8 stream api 快速提取两个 map 中键名交集的简洁方法,通过 `keyset()`、`filter()` 和 `containskey()` 实现零循环、高可读性的键匹配逻辑。
在实际开发中,经常需要比对两个 Map 结构,找出它们共有的键(key),例如用于数据校验、缓存同步或配置合并等场景。Java 8 提供了强大的 Stream API,使此类操作变得简洁而函数式。
以下是一个典型示例:
假设有两个 Map
Mapmap1 = Map.of("abc", 123, "def", 234, "jkl", 567); Map map2 = Map.of("abc", 123, "def", 234, "jddj", 567);
目标是获取同时存在于 map1 和 map2 中的所有键 —— 即 {"abc", "def"}。
✅ 推荐写法(一行流式表达):
import static java.util.stream.Collectors.toSet; SetcommonKeys = map1.keySet() .stream() .filter(map2::containsKey) // 判断该键是否也存在于 map2 中 .collect(toSet());
? 原理说明:
⚠️ 注意事项:
✅ 扩展:若需返回 List 并保持 map1 中原始插入顺序,可改用:
ListorderedCommonKeys = map1.keySet().stream() .filter(map2::containsKey) .toList(); // Java 16+,或 collect(Collectors.toList())
总之,利用 Stream 链式调用,既避免了传统 for-loop 的冗余代码,又提升了逻辑清晰度与可维护性 —— 这正是 Java 8 函数式编程的核
心优势。