1.HashSet是Set接口下面的一个实现类,HashSet集合的特点是无序不可重复的
2.HashSet存储对象时,需要重写equals方法和hashCode方法
package com.qfedu.b_;
import java.util.HashSet;
import java.util.Objects;
import java.util.Set;
class Person {
private int age;
private String name;
public Person(int age, String name) {
this.age = age;
this.name = name;
}
@Override
public String toString() {
return "Person{" +
"age=" + age +
", name='" + name + '\'' +
'}';
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public boolean equals(Object o) {
/**
* 先比较两个对象的内存地址
*/
if (this == o) return true;
/**
* 再比较两个对象的属性
*/
if (o == null || getClass() != o.getClass()) return false;
/**
* 多态的向下转型,把o转为person
*/
Person person = (Person) o;
/**
* 比较对象的属性是否全部都相等
*/
return age == person.age && Objects.equals(name, person.name);
}
@Override
public int hashCode() {
return Objects.hash(age, name);
}
}
public class Demo_03 {
public static void main(String[] args) {
/**
* 实例化HashCode集合
*/
Set<Person> set = new HashSet<>();
/**
* 实例化几个对象
*/
Person person1 = new Person(20, "张三");
Person person2 = new Person(21, "李四");
Person person3 = new Person(21, "王五");
Person person4 = new Person(20, "张三");
set.add(person1);
set.add(person2);
set.add(person3);
set.add(person4);
System.out.println(set);
/**
* 相等的两个对象的hash值相等,切只会存进集合中一个
*/
System.out.println(person1.hashCode());
System.out.println(person4.hashCode());
}
}