Collections.disjoint方法判断两集合是否无交集,遍历较小集合并用contains检查另一集合,依赖元素的equals和hashCode实现,正确重写方可确保结果准确。

Java 中的 Collections.disjoint 方法用于判断两个集合是否有交集。如果两个集合没有公共元素,返回 true;否则返回 false。
public static boolean disjoint(Collection<?> c1, Collection<?> c2)
例如,如果你有一个自定义类 Person,并希望根据姓名判断是否相同,就必须重写 equals 方法,否则 disjoint 可能无法正确识别重复元素。
以下是一个简单示例:
立即学习“Java免费学习笔记(深入)”;
Set<String> set1 = new HashSet<>(Arrays.asList("a", "b", "c"));
Set<String> set2 = new HashSet<>(Arrays.asList("d", "e", "f"));
Set<String> set3 = new HashSet<>(Arrays.asList("c", "g"));
System.out.println(Collections.disjoint(set1, set2)); // 输出 true
System.out.println(Collections.disjoint(set1, set3)); // 输出 false(因为都有 "c")
基本上就这些。只要理解它是通过“遍历小集合 + 检查大集合是否包含”来实现的,就能合理评估其性能和正确性。不复杂但容易忽略细节。
以上就是Java Collections.disjoint方法如何判断集合是否无交集的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号