您的位置:

以set遍历为中心的Java工程师

一、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工程师的基本技能之一,希望对您有所帮助。