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