zoukankan      html  css  js  c++  java
  • java判断两集合是否相同以及求取交集,并集,差集

    业务中用时需要判断两集合是否相同,所有提供一个工具方法,使用set集合的特性(元素唯一):

    private Map<String,Set<Integer>> getCategoryApiId(Set<Integer> oldAuthSet , Set<Integer> newAuthSet){
            Map<String,Set<Integer>> categoryApiId = new HashMap();
            if (oldAuthSet!=null&&newAuthSet!=null){
                //首先判断两个集合是否一致
                if (oldAuthSet.size()==newAuthSet.size()){
                    Set<Integer> tempSet = new HashSet<Integer>();
                    tempSet.addAll(oldAuthSet);
                    tempSet.addAll(newAuthSet);
                    if (tempSet.size()==oldAuthSet.size()){
                        categoryApiId =null;//未增加api个数
                        logger.info("未新增和删除api");
                    }else{
                        //1:交集;2:a-b的差集;3:并集
                        Set<Integer> apiSet1 = getApiSet(oldAuthSet, newAuthSet, 1);
                        Set<Integer> deleteAuthSet = getApiSet(oldAuthSet, apiSet1, 2);
                        Set<Integer> insertAuthSet = getApiSet(newAuthSet,oldAuthSet , 2);//获取新增的apiId
                        logger.info("删除的api:"+deleteAuthSet);
                        logger.info("新增的api:"+insertAuthSet);
                        categoryApiId.put("insertApi",insertAuthSet);
                        categoryApiId.put("datele",deleteAuthSet);
                    }
                }else{
                    //1:交集;2:a-b的差集;3:b-a的差集;4:并集
                    Set<Integer> apiSet1 = getApiSet(oldAuthSet, newAuthSet, 1);
                    Set<Integer> deleteAuthSet = getApiSet(oldAuthSet, apiSet1, 2);//获取删除的apiId
                    Set<Integer> insertAuthSet = getApiSet(newAuthSet, oldAuthSet, 2);//获取新增的apiId
                    logger.info("删除的api:"+deleteAuthSet);
                    logger.info("新增的api:"+insertAuthSet);
                    categoryApiId.put("insertApi",insertAuthSet);
                    categoryApiId.put("datele",deleteAuthSet);
                }
            }else{
                if (oldAuthSet==null&&newAuthSet!=null){    //全是新增api
                    logger.info("首次新增授权api");
                    categoryApiId.put("insertApi",newAuthSet);
                }else if (oldAuthSet!=null&&newAuthSet==null){  //未修改用户授权api的数据
                    logger.info("未增加新授权的api");
                    categoryApiId.put("datele",oldAuthSet);
                }else if (oldAuthSet==null&&newAuthSet==null){
                    logger.info("已授权api和新增授权api都为空");
                    categoryApiId =null;
                }
            }
            return categoryApiId;
        }
    
    private Set<Integer>  getApiSet(Set<Integer> oldAuthSet, Set<Integer> newAuthSet,int flag) {
            Set<Integer> result = new HashSet<Integer>();
            if(flag==1){ //求交集
                result.clear();
                result.addAll(oldAuthSet);
                result.retainAll(newAuthSet);
            }else if(flag==2){ //求差集
                result.clear();
                result.addAll(oldAuthSet);
                result.removeAll(newAuthSet);
            } else if (flag==3){ //求并集
                result.clear();
                result.addAll(oldAuthSet);
                result.addAll(newAuthSet);
            }
            return result;
        }
  • 相关阅读:
    debian 安装deb软件
    Linux的发行版之间的联系和区别
    Linux软件包安装(rpm、yum、apt-get)
    在deepin中安装docker
    使用BeanUitls提高对象拷贝效率
    Nginx下载和安装与启动
    Spring Boot 的项目打包成的 JAR 包,制作成 docker 镜像并运行
    Java并发编程实战(使用synchronized实现同步方法)
    Java7并发编程实战(一) 守护线程的创建和运行
    Java7并发编程实战(一) 线程的等待
  • 原文地址:https://www.cnblogs.com/zyanrong/p/11791508.html
Copyright © 2011-2022 走看看