一、Set的基本概念
Set是Java集合框架中的一种集合类型,它是一个不允许重复元素的集合。在Set中,元素是没有特定的顺序的,因此不支持通过下标进行访问。Set集合中的元素都具有唯一性,重复添加相同的元素只会保留其中一个元素。
在Java中,Set接口有两个主要的实现类:HashSet和TreeSet,它们分别是基于哈希表和红黑树实现的。
二、Set交集操作的概念
Set的交集操作是指,将两个Set集合中相同的元素提取出来形成一个新的Set集合。
Setset1 = new HashSet<>(); set1.add(1); set1.add(2); set1.add(3); Set set2 = new HashSet<>(); set2.add(2); set2.add(3); set2.add(4); Set intersection = new HashSet<>(set1); intersection.retainAll(set2); // 交集为{2, 3} System.out.println(intersection);
三、交集操作的实现方法
1. retainAll()
Set接口提供了retainAll()方法来计算两个集合的交集。这个方法会修改调用者对象,将其保留在传递的Set对象中出现的元素,而删除不在传递的Set对象中的元素。
Setset1 = new HashSet<>(); set1.add(1); set1.add(2); set1.add(3); Set set2 = new HashSet<>(); set2.add(2); set2.add(3); set2.add(4); set1.retainAll(set2); // set1中只保留{2, 3} System.out.println(set1);
2. addAll()和removeAll()
除了使用retainAll()方法外,我们还可以使用addAll()和removeAll()方法来计算两个Set集合的交集。
Setset1 = new HashSet<>(); set1.add(1); set1.add(2); set1.add(3); Set set2 = new HashSet<>(); set2.add(2); set2.add(3); set2.add(4); Set intersection = new HashSet<>(set1); intersection.addAll(set2); // 将set2中的元素全部添加到intersection集合中 intersection.removeAll(Collections.singleton(1)); // 移除不在交集中的元素 intersection.removeAll(Collections.singleton(4)); // 移除不在交集中的元素 System.out.println(intersection); // 交集为{2, 3}
四、使用Lambda表达式计算Set交集
Java 8引入了Lambda表达式,我们可以使用Lambda表达式来计算Set集合的交集。
Setset1 = new HashSet<>(); set1.add(1); set1.add(2); set1.add(3); Set set2 = new HashSet<>(); set2.add(2); set2.add(3); set2.add(4); Set intersection = set1.stream() .filter(set2::contains) .collect(Collectors.toSet()); System.out.println(intersection); // 交集为{2, 3}
五、总结
本文详细介绍了Java集合框架中Set集合的交集操作,包括使用retainAll()方法、addAll()和removeAll()方法、Lambda表达式和Stream API等方法来计算Set集合的交集。在实际开发中,我们应该根据具体情况来选择不同的方法来进行计算。