equals和hashcode總結

equals和hashcode總結:

1.equals方法沒有重寫的話,用於判斷對象的內存地址引用是否是用一個地址。重寫之後一般用來比較對象的內容是否相等(比如student對象,裏面有姓名和年齡,我們重寫

equals方法來判斷只要姓名和年齡相同就認爲是用一個學生)。

2.hashCode是jdk根據對象的地址或者字符串或者數字算出來的int類型的數值,當然你也可以重寫它,hashcode方法只有在集合中用到。

3.對象放入集合中時,先判斷hashcode是否相等,再判斷equals是否相等,都相等就算是同一個對象,list則可以放入,set因爲不允許重複所以不會放入。

4.例如:

public class Student {

        private int age;

        private String name;

        

        public Student(int age ,String name){

            this.age = age;

            this.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;

        }

        //重寫equals方法,判斷姓名和年齡相同就是相等的

        public boolean equals(Object o){

            if(o == null){

                return false;

            }

            if(this.getClass() != o.getClass()){

             return false;   

            }

            Student student = (Student)o;

            if(name == null){

                return false;

            }

            if(age==student.getAge()&&name.equals(student.getName())){

                return true;

            }

            return false;

        }

        

    public static void main(String[] args) {

        Student studentOne = new Student(1,"yjc");

        Student studentTwo = new Student(1,new String("yjc"));

        System.out.println(studentOne.equals(studentTwo));

        System.out.println("1: "+studentOne.getName().hashCode());

        System.out.println("2: "+studentTwo.getName().hashCode());

    }

    //輸出結果:true

                1: 119666

                2: 119666

 

}

以上可以看出,兩個String都叫"yjc",無論是直接"yjc"還是new String("yjc"),他們的hashcode都相同。所以在重寫hashcode方法時可以運用這一點。

比如你希望如果姓名和年齡相同,不僅equals相同,他們的hashcode也要相同,可以這樣重寫hashcode:

public int hashcode(){

final int prime = 31;

int result = 1;

result = prime*result + age;

result = prime*result + (name == null? 0 : name.hashcode());

return result;//直接寫age+(name == null? 0 : name.hashcode())也行就是感覺太簡單了0.0

}

這樣一來兩個姓名和年齡相同的Student對象就是同一個對象了,放入set中會被認爲是同一個,無論放幾個這樣的對象,set.size()都是等於1。

同樣,HashMap因爲key也是唯一的,HashMap對象是根據其Key的hashCode來定位存儲位置,並使用equals(key)獲取對應的Value,所以在put時判斷key是否重複用到了hashcode和equals,若重複了則會覆蓋。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章