我们在对非基本类型进行比较时,往往需要重写 equals() 方法来判断两者是否相等。
比如我们现在定义一个 Student 类,希望只要其 number 相等,就认为这是同一个 Student。
public class Student {
private int number;
private String name;
public Student(int number, String name) {
this.number = number;
this.name = name;
}
public int getNumber() {
return number;
}
public void setNumber(int number) {
this.number = number;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Student{" +
"number=" + number +
", name='" + name + '\'' +
'}';
}
@Override
public boolean equals(Object o) {
Student student = (Student) o;
if (number == student.getNumber()) {
return true;
}
return false;
}
}
public class StudentTest {
public static void main(String[] args) {
Student s1 = new Student(1, "王小明");
Student s2 = new Student(1, "王大明");
System.out.println(s1.equals(s2));
}
}
true
咋一看好像没啥问题,但我们把 Student 放入 Set 中再看看。
public class StudentTest {
public static void main(String[] args) {
Student s1 = new Student(1, "王小明");
Student s2 = new Student(1, "王大明");
Set<Student> set = new HashSet<>();
set.add(s1);
set.add(s2);
System.out.println(set);
}
}
[Student{number=1, name='王大明'}, Student{number=1, name='王小明'}]
我们发现即使两者通过 equals() 返回 true,代表两者相等,但放入 Set 中时,还是被认为是两个不同的对象。
但我们的想法是,希望相同 number 的 Student 放入 Set 时,可以被认作为同一个 Student ,该如何操作呢?
其实在 Set 中,判断 key 是否重复,不仅仅是通过调用 equals() 方法来判断两者是否相等,还需要判断 hashcode() 方法返回的值是否一致。
我们只需重写 Student 的 hashCode() 方法,让相同编号的 number 返回相同的值即可。之后再将 number 相同的 Student 放入 Set 时,就会被认作为重复元素,不会再执行更新操作。
public class Student {
private int number;
private String name;
public Student(int number, String name) {
this.number = number;
this.name = name;
}
public int getNumber() {
return number;
}
public void setNumber(int number) {
this.number = number;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Student{" +
"number=" + number +
", name='" + name + '\'' +
'}';
}
@Override
public boolean equals(Object o) {
Student student = (Student) o;
if (number == student.getNumber()) {
return true;
}
return false;
}
@Override
public int hashCode() {
return getNumber();
}
}
public class StudentTest {
public static void main(String[] args) {
Student s1 = new Student(1, "王小明");
Student s2 = new Student(1, "王大明");
Student s3 = new Student(1, "王二明");
Set<Student> set = new HashSet<>();
set.add(s1);
set.add(s2);
set.add(s3);
System.out.println(set);
}
}
[Student{number=1, name='王小明'}]
本次分享至此结束,希望本文对你有所帮助,若能点亮下方的点赞按钮,在下感激不尽,谢谢您的【精神支持】。
若有任何疑问,也欢迎与我交流,若存在不足之处,也欢迎各位指正!