0

0

如何在Java中查找两个List的对称差集_交并补运算与Apache CollectionUtils应用

P粉602998670

P粉602998670

发布时间:2026-03-17 11:02:01

|

474人浏览过

|

来源于php中文网

原创

Java原生List计算对称差集需先复制再组合removeAll和addAll;推荐用Apache Commons Collections4的CollectionUtils.disjunction(),它返回新集合、不修改原List,但依赖正确实现的equals()且不支持泛型推断。

如何在java中查找两个list的对称差集_交并补运算与apache collectionutils应用

Java原生List怎么算对称差集(A⊕B)

对称差集 = 属于A或B但不同时属于两者的元素,即 (A - B) ∪ (B - A)。Java标准库没直接提供这个操作,得自己组合 removeAlladdAll,但必须注意顺序和副作用。

  • 别直接在原始List上做 removeAll —— 它会修改原集合,后续再用就错了
  • 推荐先复制:用 new ArrayList(listA)new ArrayList(listB) 起手
  • 计算步骤是:① listA_copy.removeAll(listB);② listB_copy.removeAll(listA);③ listA_copy.addAll(listB_copy)
  • 如果List含null或自定义对象,确保 equals()hashCode() 正确实现,否则 removeAll 会漏匹配

Apache Commons Collections的CollectionUtils.disjunction()真能省事?

能,但有隐含前提:它底层调用的是 CollectionUtils.retainAll()CollectionUtils.removeAll() 的组合逻辑,仍依赖 equals(),且返回的是新集合(不改原List)。

  • 必须引入 commons-collections4(不是老版 commons-collections),Maven坐标是 org.apache.commons:commons-collections4:4.4
  • 用法简单:CollectionUtils.disjunction(listA, listB),返回 Collection 类型,通常要显式转成 ArrayList
  • 性能上比手写略低——它内部做了两次遍历+构造新集合,大数据量时不如预分配容量的手写版本
  • 不支持泛型推断(Java 8),得写 CollectionUtils.<string>disjunction(listA, listB)</string> 或接收为 Collection> 再转型

交集、并集、补集这些也顺手一起算?

原生和Commons都有对应方法,但命名和行为细节容易混淆:

  • 交集:CollectionUtils.intersection(A, B) 或手写 new ArrayList(A); retainAll(B)
  • 并集:CollectionUtils.union(A, B)(去重) vs 原生 new ArrayList(A); addAll(B)(不去重)——注意语义差异
  • 补集(A - B):CollectionUtils.subtract(A, B),等价于 new ArrayList(A); removeAll(B)
  • 所有操作都要求元素可比较;若List含重复元素,subtractdisjunction 会按出现次数“抵消”,比如 A=[1,1,2]、B=[1,3] → subtract(A,B) 结果是 [1,2],不是 [2]

为什么用Stream API写对称差集反而容易出错

有人想用 stream().filter() + !other.contains() 实现,但实际踩坑不少:

HIX Translate
HIX Translate

由 ChatGPT 提供支持的智能AI翻译器

下载

立即学习Java免费学习笔记(深入)”;

  • contains() 在ArrayList里是O(n)复杂度,嵌套两层stream会变成O(n²),10k元素就明显卡顿
  • 写成 A.stream().filter(x -> !B.contains(x)).collect(...) ∪ B.stream().filter(x -> !A.contains(x)).collect(...) 时,两次 contains 都走线性扫描,没复用
  • 若想优化,得先转 HashSetSet<t> setB = new HashSet(B)</t>,再用 setB.contains(x) —— 但这手动管理Set,代码反而比 CollectionUtils.disjunction() 更长
  • Stream结果默认是无序的,而原List顺序可能重要;若需保序,得用 LinkedHashSet 中转,又多一层转换成本

真正需要保序+高性能+去重的场景,老实用 HashSet 手写更可控,但日常开发里,Commons那几个工具方法已经够用——只要记得它不处理null安全,也不做深比较。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Java Maven专题
Java Maven专题

本专题聚焦 Java 主流构建工具 Maven 的学习与应用,系统讲解项目结构、依赖管理、插件使用、生命周期与多模块项目配置。通过企业管理系统、Web 应用与微服务项目实战,帮助学员全面掌握 Maven 在 Java 项目构建与团队协作中的核心技能。

0

2025.09.15

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

255

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1153

2024.03.01

c语言union的用法
c语言union的用法

c语言union的用法是一种特殊的数据类型,它允许在相同的内存位置存储不同的数据类型,union的使用可以帮助我们节省内存空间,并且可以方便地在不同的数据类型之间进行转换。使用union时需要注意对应的成员是有效的,并且只能同时访问一个成员。本专题为大家提供union相关的文章、下载、课程内容,供大家免费下载体验。

129

2023.09.27

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

116

2026.03.13

apache是什么意思
apache是什么意思

Apache是Apache HTTP Server的简称,是一个开源的Web服务器软件。是目前全球使用最广泛的Web服务器软件之一,由Apache软件基金会开发和维护,Apache具有稳定、安全和高性能的特点,得益于其成熟的开发和广泛的应用实践,被广泛用于托管网站、搭建Web应用程序、构建Web服务和代理等场景。本专题为大家提供了Apache相关的各种文章、以及下载和课程,希望对各位有所帮助。

422

2023.08.23

apache启动失败
apache启动失败

Apache启动失败可能有多种原因。需要检查日志文件、检查配置文件等等。想了解更多apache启动的相关内容,可以阅读本专题下面的文章。

939

2024.01.16

Java 流式处理与 Apache Kafka 实战
Java 流式处理与 Apache Kafka 实战

本专题专注讲解 Java 在流式数据处理与消息队列系统中的应用,系统讲解 Apache Kafka 的基础概念、生产者与消费者模型、Kafka Streams 与 KSQL 流式处理框架、实时数据分析与监控,结合实际业务场景,帮助开发者构建 高吞吐量、低延迟的实时数据流管道,实现高效的数据流转与处理。

182

2026.02.04

Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建
Nginx跨平台安装实操指南:Windows、macOS与Linux环境快速搭建

本指南详解Nginx在Windows、macOS及Linux系统的安装全流程。涵盖官方包解压、Homebrew一键部署、APT/YUM源配置及Docker容器化方案。无论新手或开发者,均可快速搭建运行环境,掌握跨平台核心指令,为后续配置与调优奠定坚实基础。

10

2026.03.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.5万人学习

C# 教程
C# 教程

共94课时 | 11.5万人学习

Java 教程
Java 教程

共578课时 | 83.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号