一、set簡介與基本操作
set是一種不包含重複元素的集合,常用的實現類有HashSet、TreeSet、LinkedHashSet等。在Java中,set的遍歷是基本操作之一,也是需要掌握的基本技能之一。
Set<String> set = new HashSet<>();
set.add("a");
set.add("b");
set.add("c");
for(String str : set){
System.out.println(str);
}
以上代碼演示了set的創建、添加元素以及遍歷操作。需要注意的是,在set中,元素的順序並不是按照添加的順序,而是按照元素的哈希碼進行排序。
二、使用set實現去重
由於set的特點是不包含重複元素,因此可以使用set來實現對數據的去重。以下代碼演示了如何使用set實現對字元串數組的去重:
String[] arr = {"a", "b", "c", "a", "c", "d"};
Set<String> set = new HashSet<>(Arrays.asList(arr));
for(String str : set){
System.out.println(str);
}
以上代碼中,將字元串數組轉化為List並傳入HashSet構造方法中,這樣就可以得到去重後的set集合。通過遍歷set集合,可以輸出去重後的結果。
三、使用set對對象進行去重
在實際開發中,有時需要對對象進行去重,可以使用set實現。以下代碼演示了如何使用set對Person對象進行去重:
public class Person {
private String name;
private int age;
// 省略構造方法和getter/setter方法
@Override
public boolean equals(Object obj) {
if(obj instanceof Person){
Person person = (Person)obj;
return this.name.equals(person.name) && this.age == person.age;
}
return false;
}
@Override
public int hashCode() {
int result = 17;
result = result * 31 + name.hashCode();
result = result * 31 + age;
return result;
}
}
public static void main(String[] args) {
Person[] arr = {new Person("張三", 18), new Person("李四", 20),
new Person("張三", 18), new Person("王五", 19)};
Set<Person> set = new HashSet<>(Arrays.asList(arr));
for(Person p : set){
System.out.println(p.getName() + " " + p.getAge());
}
}
以上代碼中,Person類實現了equals和hashCode方法,這是Java語言中判斷是否相等的基本方法。然後將Person對象數組轉化為List並傳入HashSet構造方法中,這樣就可以得到去重後的set集合。通過遍歷set集合,可以輸出去重後的結果。
四、使用TreeSet進行排序
除了使用HashSet進行set集合的遍歷和去重外,還可以使用TreeSet進行排序。以下代碼演示了如何使用TreeSet對整數進行升序排序:
Set<Integer> set = new TreeSet<>();
set.add(5);
set.add(3);
set.add(7);
for(Integer i : set){
System.out.println(i);
}
以上代碼中,使用TreeSet集合進行元素的添加操作,由於TreeSet具有可排序性,在遍歷時會按照升序排列。
五、結語
本文從set集合的基本操作、使用set實現去重、使用set對對象進行去重、使用TreeSet進行排序四個方面進行了闡述。set遍歷作為Java工程師的基本技能之一,希望對您有所幫助。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/236909.html