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

一、使用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);
    }
}
相关推荐
亓才孓5 分钟前
[SpringIOC]NoUniqueBeanDefinitionException
java·spring
开开心心就好8 分钟前
实用PDF批量加马赛克,抹除敏感信息绿色版
java·linux·开发语言·网络·人工智能·pdf·word2vec
kong790692814 分钟前
SpringBoot Rest风格 API
java·spring boot·后端
Moshow郑锴24 分钟前
WindowsRemoteAdmin(超级马里奥像素版)专为无远程登录桌面系统打造的便携式管理工具
java·powershell·远程控制·远程桌面·系统运维
骇城迷影26 分钟前
代码随想录:栈和队列篇
java·服务器·算法
重生之后端学习34 分钟前
124. 二叉树中的最大路径和
java·数据结构·算法·职场和发展·深度优先·图论
Renhao-Wan37 分钟前
Java 算法实践(五):二叉树遍历与常见算法题
java·数据结构·算法
知识即是力量ol39 分钟前
口语八股——计算机网络篇(终篇)
java·计算机网络·面试·八股
洛_尘40 分钟前
测试6:自动化测试--概念篇(JAVA)
java·开发语言·测试
追随者永远是胜利者40 分钟前
(LeetCode-Hot100)39. 组合总和
java·算法·leetcode·职场和发展·go