Java里List取并集方法retainAll不能用来判断是否有重复数据!

网上找的源码

public boolean retainAll(Collection<?> c){

     boolean  modified =  false ;
     Iterator<E> e = iterator();
     while  (e.hasNext()){
         if  (!c.contains(e.next())){
             e.remove();
             modified =  true ;
         }
     }
     return  modified;
}
我用这个方法是做Excel导入功能的时候判断数据库里是否已存在制定编号。随便测试一下可用,可实际上没那么简单,最大一个坑就是如果你导入的数据是一模一样的,这个方法无法去判断是否有重复数据.
从源码也能看出来!如果list1 有a,b,c三个值,而list2有b,c,d三个值.那么list1.retainAll(list2);之后会返回true,list1集合值为b,c。
如果list1的值和list2的值都一样是a,b,c那么会返回false,list1值不变。
如果list1的值为a,b,c,a,b,c,a,b,c那么还是会返回false,list1值不变。
如果你拿了一个Excel导入多次是不能判断是否有重复数据的!
如果list1的值为a,b,c,list2的值为d,e,f那么list1.retainAll()后list1就会被清空,list1.size()为0;
如果想判断是否有重复数据,则要先用containsAll判断一下再用retainAll方法:
if(dbCode.containsAll(excelCode)){
return false;
}else{
 boolean flag=dbCode.retainAll(excelCode);
    if(dbCode.size()==0){ 
    //如果dbCode.size()==0证明dbCode原本集合里的值和excelCode的值没一个对应的.
        return true;
    }
     return flag;

}

转载于:https://www.cnblogs.com/345214483-qq/p/5029802.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值