集合并集交集差集【工具类】

一、使用Stream流进行处理

在Java开发中,对于集合的操作是非常常见的,特别是交集、并集和差集这样的操作。这些操作可以通过Java 8中的Stream API来实现。

•交集:取两个集合中相同的部分。例如,如果我们有两个List集合:list1和list2,我们可以使用list1.stream().filter(list2::contains).collect(Collectors.toList())来获取它们的交集。

•并集:将两个集合合并为一个集合。同样使用Stream API,我们可以使用Stream.concat(list1.stream(), list2.stream()).collect(Collectors.toList())来得到两个集合的并集。此外,还可以通过先将两个集合合并,然后使用distinct()方法去重,最后将结果收集到一个新的集合中来获得并集。

•差集:取两个集合中不相同的部分。例如,使用list1.stream().filter(item -> !list2.contains(item)).collect(toList())可以获取list1相对于list2的差集。同样地,我们也可以获取list2相对于list1的差集。

二、使用commons包处理

推荐使用封装后的工具类进行处理,代码如下所示:

java 复制代码
import org.apache.commons.collections.CollectionUtils;
import java.util.List;

/**
 * 集合 并集 交集 差集
 * @param <T>
 */
public class CollectionHigherOrderUtils<T> {

    /**
     * 获取两个列表的并集
     *
     * @param list  第一个列表
     * @param list2 第二个列表
     * @return 两个列表的并集,如果任一列表为null,则返回null
     */
    public static <T> List<T> unionList(List<T> list, List<T> list2) {
        if (list == null || list2 == null) {
            return null; // 或者你可以返回一个空的列表
        }
        return (List<T>) CollectionUtils.union(list, list2);
    }

    /**
     * 获取两个列表的交集
     *
     * @param list  第一个列表
     * @param list2 第二个列表
     * @return 两个列表的交集,如果任一列表为null,则返回null
     */
    public static <T> List<T> intersectionList(List<T> list, List<T> list2) {
        if (list == null || list2 == null) {
            return null; // 或者你可以返回一个空的列表
        }
        return (List<T>) CollectionUtils.intersection(list, list2);
    }

    /**
     * 获取两个列表的对称差集(即只在一个列表中出现的元素)
     *
     * @param list  第一个列表
     * @param list2 第二个列表
     * @return 两个列表的对称差集,如果任一列表为null,则返回null
     */
    public static <T> List<T> symmetricDifferenceList(List<T> list, List<T> list2) {
        if (list == null || list2 == null) {
            return null; // 或者你可以返回一个空的列表
        }
        return (List<T>) CollectionUtils.disjunction(list, list2);
    }

    /**
     * 获取第一个列表中存在但第二个列表中不存在的元素(即差集)
     *
     * @param list  第一个列表
     * @param list2 第二个列表
     * @return 第一个列表的差集,如果任一列表为null,则返回null
     */
    public static <T> List<T> subtractList(List<T> list, List<T> list2) {
        if (list == null || list2 == null) {
            return null; // 或者你可以返回一个空的列表
        }
        return (List<T>) CollectionUtils.subtract(list, list2);
    }
}
相关推荐
我没想到原来他们都是一堆坏人39 分钟前
(未完待续...)如何编写一个用于构建python web项目镜像的dockerfile文件
java·前端·python
沙二原住民1 小时前
提升数据库性能的秘密武器:深入解析慢查询、连接池与Druid监控
java·数据库·oracle
Jerry&Grj1 小时前
SpringBoot埋点功能技术实现方案深度解析:架构设计、性能优化与扩展性实践
java·微服务·性能优化·springboot·架构设计·埋点技术
没有bug.的程序员1 小时前
Redis Stream:轻量级消息队列深度解析
java·数据库·chrome·redis·消息队列
用户8160791833332 小时前
告别“魔法”:包你解决 Gradle 的下载慢问题
java
当归10242 小时前
SQL Server死锁排查实战指南
java·服务器·网络
echoyu.2 小时前
消息队列-初识kafka
java·分布式·后端·spring cloud·中间件·架构·kafka
little_xianzhong2 小时前
关于对逾期提醒的定时任务~改进完善
java·数据库·spring boot·spring·mybatis
百锦再3 小时前
脚本语言的大浪淘沙或百花争艳
java·开发语言·人工智能·python·django·virtualenv·pygame
小猪咪piggy3 小时前
【JavaEE】(23) 综合练习--博客系统
java·数据库·java-ee