一、Set的基本概念
Set是Java集合框架中的一種集合類型,它是一個不允許重複元素的集合。在Set中,元素是沒有特定的順序的,因此不支持通過下標進行訪問。Set集合中的元素都具有唯一性,重複添加相同的元素只會保留其中一個元素。
在Java中,Set接口有兩個主要的實現類:HashSet和TreeSet,它們分別是基於哈希表和紅黑樹實現的。
二、Set交集操作的概念
Set的交集操作是指,將兩個Set集合中相同的元素提取出來形成一個新的Set集合。
Set set1 = 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對象中的元素。
Set set1 = 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集合的交集。
Set set1 = 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集合的交集。
Set set1 = 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集合的交集。在實際開發中,我們應該根據具體情況來選擇不同的方法來進行計算。
原創文章,作者:LCDN,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/149018.html