CollectionUtils的一个bug

CollectionUtils中求集合差集的方法有bug:

按照集合论的定义:

一般地,记A,B是两个集合,则所有属于A且不属于B的元素构成的集合,叫做集合A减集合B(或集合A与集合B之差),类似地,对于集合A、B,我们把集合{x∣x∈A,且x∉B}叫做A与B的差集,记作A-B(或A\B),即A-B={x|x∈A且x∉ B}(或A\B={x|x∈A且x ∉B},同理 B-A={x∣x∈B且x∉A} 叫做B与A的差集.

 

那么很显然,求如下a,b两个集合的差集:

A: {1,2,3,3,4,5}

B: {3,4,4,5,6,7}

 

结果应该是{1,2} 

 

但是调用subtract方法,运行结果却是:

 

{1,2,3}

一看code就了然了:

public static Collection subtract(final Collection a, final Collection b) {

        ArrayList list = new ArrayList( a );

        for (Iterator it = b.iterator(); it.hasNext();) {

            list.remove(it.next());

        }

        return list;

 

    }

 

它只把A中的第一个3删掉后,下次迭代就用4去比了。所以A中的第二个3留下了。

此外,这个方法的效率也不高,所以还是慎用吧

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值