一、Set集合简介
Set是Java集合框架下的一个集合接口,用于存储不可重复的元素,即每个元素都是唯一的。Set常用的实现类有HashSet、LinkedHashSet和TreeSet。
二、遍历Set集合的方法
1. 迭代器遍历
迭代器是一种用于访问集合元素的接口,通过迭代器可以按某种顺序依次访问集合中的每个元素。
Set<String> set = new HashSet<>(); set.add("apple"); set.add("orange"); set.add("banana"); Iterator<String> it = set.iterator(); while(it.hasNext()) { String str = it.next(); System.out.println(str); }
代码解释:
首先创建一个HashSet集合,然后向集合中添加三个元素。接着使用iterator()方法获取集合的迭代器对象,使用while循环和hasNext()方法判断是否还有下一个元素,如果存在则使用next()方法获取下一个元素。
2. 增强的for循环遍历
Java SE5及以上版本提供了一种方便的方式遍历集合,即增强的for循环。增强的for循环可以按照集合元素的迭代顺序依次访问每个元素。
Set<String> set = new HashSet<>(); set.add("apple"); set.add("orange"); set.add("banana"); for(String str : set) { System.out.println(str); }
代码解释:
与前面的例子相同,首先创建一个HashSet集合并向集合中添加三个元素。接着使用增强的for循环依次遍历集合中的元素,将元素赋值给str变量,然后输出。
3. Lambda表达式遍历
Java 8引入的Lambda表达式可以使用更简单的方式遍历集合,并且还支持并行处理。
Set<String> set = new HashSet<>(); set.add("apple"); set.add("orange"); set.add("banana"); set.forEach(str -> System.out.println(str));
代码解释:
首先创建一个HashSet集合并向集合中添加三个元素。接着使用forEach()方法遍历集合中的元素,Lambda表达式中的str即是集合中的元素,然后输出。
三、Set集合元素排序
1. HashSet集合不排序
HashSet不保证元素的顺序,元素的位置可能随时被修改。如果需要对元素排序,可以使用TreeSet或LinkedHashSet。
Set<String> set = new HashSet<>(); set.add("apple"); set.add("orange"); set.add("banana"); for(String str : set) { System.out.println(str); }
代码解释:
同样先创建一个HashSet集合并向集合中添加三个元素。使用增强的for循环遍历集合输出元素,由此可以看出HashSet集合是不排序的。
2. TreeSet集合排序
TreeSet集合可以按照元素的自然排序(从小到大)或者指定的Comparator排序。
Set<String> set = new TreeSet<>(); set.add("apple"); set.add("orange"); set.add("banana"); for(String str : set) { System.out.println(str); }
代码解释:
同样先创建一个TreeSet集合并向集合中添加三个元素。使用增强的for循环遍历集合输出元素,由此可以看出TreeSet集合是按照元素的自然排序进行排序的。
3. LinkedHashSet集合插入顺序排序
LinkedHashSet集合可以按照元素被插入的顺序进行排序,插入的新元素会被放在集合中最后一个元素的后面。
Set<String> set = new LinkedHashSet<>(); set.add("apple"); set.add("orange"); set.add("banana"); for(String str : set) { System.out.println(str); }
代码解释:
同样先创建一个LinkedHashSet集合并向集合中添加三个元素。使用增强的for循环遍历集合输出元素,可以发现集合中的元素顺序与插入顺序一致。
四、Set集合的并集、交集和差集操作
1. 并集操作
Set集合的并集操作可以将两个集合中的所有不同元素合并到一个新的集合中。可以使用addAll()方法实现。
Set<String> set1 = new HashSet<>(); set1.add("apple"); set1.add("orange"); set1.add("banana"); Set<String> set2 = new HashSet<>(); set2.add("pear"); set2.add("banana"); set2.add("peach"); Set<String> unionSet = new HashSet<>(set1); unionSet.addAll(set2); for(String str : unionSet) { System.out.println(str); }
代码解释:
先创建两个HashSet集合set1和set2,并向集合中添加元素。然后通过set1创建一个新的HashSet集合unionSet,并使用addAll()方法将set2中的所有元素加入到unionSet中,这样就得到了两个集合的并集。使用增强的for循环遍历unionSet输出元素。
2. 交集操作
Set集合的交集操作可以获取两个集合中的共同元素。可以使用retainAll()方法实现。
Set<String> set1 = new HashSet<>(); set1.add("apple"); set1.add("orange"); set1.add("banana"); Set<String> set2 = new HashSet<>(); set2.add("pear"); set2.add("banana"); set2.add("peach"); Set<String> intersectionSet = new HashSet<>(set1); intersectionSet.retainAll(set2); for(String str : intersectionSet) { System.out.println(str); }
代码解释:
先创建两个HashSet集合set1和set2,并向集合中添加元素。然后通过set1创建一个新的HashSet集合intersectionSet,并使用retainAll()方法获取set1和set2中共同的元素,这样就得到了两个集合的交集。使用增强的for循环遍历intersectionSet输出元素。
3. 差集操作
Set集合的差集操作可以获取在集合A中出现但是不在集合B中出现的元素。可以使用removeAll()方法实现。
Set<String> set1 = new HashSet<>(); set1.add("apple"); set1.add("orange"); set1.add("banana"); Set<String> set2 = new HashSet<>(); set2.add("pear"); set2.add("banana"); set2.add("peach"); Set<String> differenceSet = new HashSet<>(set1); differenceSet.removeAll(set2); for(String str : differenceSet) { System.out.println(str); }
代码解释:
先创建两个HashSet集合set1和set2,并向集合中添加元素。然后通过set1创建一个新的HashSet集合differenceSet,并使用removeAll()方法获取在set1中出现但是不在set2中出现的元素,这样就得到了set1和set2的差集。使用增强的for循环遍历differenceSet输出元素。