首頁  >  文章  >  Java  >  等於和哈希碼

等於和哈希碼

(*-*)浩
(*-*)浩轉載
2019-08-24 15:53:482357瀏覽

equals和hashcode總結:

等於和哈希碼

#equals方法沒有重寫的話,用於判斷物件的記憶體位址引用是否是用一個地址。重寫之後一般用來比較對象的內容是否相等(例如student對象,裡面有姓名和年齡,我們重寫equals方法來判斷只要姓名和年齡相同就認為是用一個學生)。

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

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

 例如:

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,若重複了則會覆蓋。

以上是等於和哈希碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除