贝利信息

Java里如何找出两个集合的差集_集合差集运算示例

日期:2025-12-30 00:00 / 作者:P粉602998670
Java中求集合差集核心用removeAll():A.removeAll(B)得A−B,需复制可修改集合;自定义对象须重写equals/hashCode;对称差集需组合计算;Stream方式适合只读场景。

Java 中找出两个集合的差集,核心是用 removeAll() 方法:它会从调用方集合中移除所有存在于参数集合中的元素,结果即为“调用方对参数方的差集”(A − B)。

基本差集:A 减去 B

这是最常用场景:保留集合 A 中有、但集合 B 中没有的元素。

示例:

List a = Arrays.asList("apple", "banana", "cherry");
List b = Arrays.asList("banana", "date");

List diff = new ArrayList(a); // 复制一份
diff.removeAll(b); // 移除 b 中所有元素
System.out.println(diff); // [apple, cherry]

注意元素类型必须正确重写 equals 和 hashCode

如果集合里是自定义对象(比如 User 类),removeAll() 能否正确识别“相同元素”,完全取决于该类是否重写了 equals()hashCode()

对称差集(A Δ B):只在其中一个集合中出现的元素

对称差集 = (A −

B) ∪ (B − A),即“互斥部分”。Java 没有内置方法,但可以组合实现:

示例(用 Set 更合适,避免重复):

Set a = Set.of("a", "b", "c");
Set b = Set.of("b", "c", "d");

Set symDiff = new HashSet(a);
symDiff.removeAll(b);
symDiff.addAll(new HashSet(b) {{ removeAll(a); }});
System.out.println(symDiff); // [a, d]

Stream 方式(Java 8+,适合只读场景)

如果不想修改原集合,且偏好函数式风格,可用 Stream 过滤:

基本上就这些。差集运算本身不复杂,但容易忽略可变性、对象相等性、性能这三点。