集合操作的利器:CollectionUtils

本文介绍如何使用Apache Commons Collections库中的CollectionUtils类进行集合操作,包括并集、交集、交集的补集和集合相减,并通过具体示例展示了这些方法的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用 CollectionUtils 中四个方法之一执行集合操作.这四种分别是 union(),intersection();disjunction(); subtract();
下列例子就是演示了如何使用上述四个方法处理两个 Collection;
注: 这些方法都是数学的集合算法

import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.List;

import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang.ArrayUtils;

public class CollectionUtilsIntro {
 @SuppressWarnings("unchecked")
 public static void main(String[] args) {
  String[] arrayA = new String[] { "1", "2", "3", "3", "4", "5" };
  String[] arrayB = new String[] { "3", "4", "4", "5", "6", "7" };

  List<String> a = Arrays.asList(arrayA);
  List<String> b = Arrays.asList(arrayB);
  //并集
  Collection<String> union = CollectionUtils.union(a, b);
  //交集
  Collection<String> intersection = CollectionUtils.intersection(a, b);
  //交集的补集
  Collection<String> disjunction = CollectionUtils.disjunction(a, b);
  //集合相减
  Collection<String> subtract = CollectionUtils.subtract(a, b);

  Collections.sort((List<String>) union);
  Collections.sort((List<String>) intersection);
  Collections.sort((List<String>) disjunction);
  Collections.sort((List<String>) subtract);

  System.out.println("A: " + ArrayUtils.toString(a.toArray()));
  System.out.println("B: " + ArrayUtils.toString(b.toArray()));
  System.out.println("--------------------------------------------");
  System.out.println("Union(A, B): " + ArrayUtils.toString(union.toArray()));
  System.out.println("Intersection(A, B): " + ArrayUtils.toString(intersection.toArray()));
  System.out.println("Disjunction(A, B): " + ArrayUtils.toString(disjunction.toArray()));
  System.out.println("Subtract(A, B): " + ArrayUtils.toString(subtract.toArray()));
 }
}

 

输出如下:
A: {1,2,3,3,4,5}
B: {3,4,4,5,6,7}
--------------------------------------------
Union(A, B): {1,2,3,3,4,4,5,6,7}
Intersection(A, B): {3,4,5}
Disjunction(A, B): {1,2,3,4,6,7}
Subtract(A, B): {1,2,3}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值