Java重寫equals及hashcode方法流程解析
阿新 • • 發佈:2020-04-17
初步探索
首先我們要了解equals方法是什麼,hashcode方法是什麼。
equals方法
equals 是java的obejct類的一個方法,equals的原始碼如下:
public boolean equals(Object paramObject){ return(this == paramObject); }
由此我們可以看到equals是用來比較兩個物件的記憶體地址是否相等。
hashCode方法
hashCode方法是本地方法,用於計算出物件的一個雜湊值,用於判斷在集合中物件是否重複的關鍵。
一條定理
equals相同的物件,hashCode必然相同。
程式碼示例
建立一個Student類。
public class Student { private String name; private int age; private String QQ; @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Student student = (Student) o; return age == student.age && Objects.equals(name,student.name) && Objects.equals(QQ,student.QQ); } }
在 student 類中,我們重寫了equals方法。
書寫一個測試類
public class Test { public static void main(String[] args) { Student student = new Student(); Student student2 = new Student(); System.out.println(student.equals(student2)); //true System.out.println(student.hashCode()); //356573597 System.out.println(student2.hashCode()); //1735600054 HashMap<Student,String> map = new HashMap<>(); map.put(student,"123"); map.put(student2,"456"); System.out.println(map.get(student)); System.out.println(map.get(student2)); } }
輸出
true
356573597 student 的hashcode值
1735600054 student 2的hashcode值
123
456
此時,我們發現 equals 相等的物件,hashcode卻不相等,同時在map中用不同的物件進行了儲存,map計算出來的hash值不同,但equals卻相同。這時候懵了。到底兩個物件一樣不一樣呢。
所以我們在重寫equals的時候,必須重寫hashcode。
重新定義 student 類
public class Student { private String name; private int age; private String QQ; @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Student student = (Student) o; return age == student.age && Objects.equals(name,student.QQ); } @Override public int hashCode() { return Objects.hash(name,age,QQ); } }
再次測試
public class Test { public static void main(String[] args) { Student student = new Student(); Student student2 = new Student(); System.out.println(student.equals(student2)); //true System.out.println(student.hashCode()); // 29791 System.out.println(student2.hashCode()); // 29791 HashMap<Student,"456"); System.out.println(map.get(student)); //456 System.out.println(map.get(student2)); //456 } }
最後的輸出
true
29791 //相同的物件
29791
456 //說明以一個值key儲存,相同的值
456
幾條定理
1、兩個物件的equals相等,hashcode必然相等。
2、兩個物件不等,hashcode也可能相等。
3、hashcode相等,物件不一定相等。
4、hashcode不等,物件一定不等。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。