如何正確重寫Java中的hashCode方法

小樊
81
2024-09-23 09:59:35
欄目: 編程語言

在Java中,當(dāng)你重寫一個(gè)對(duì)象的hashCode()方法時(shí),需要確保滿足以下幾點(diǎn):

  1. 在同一個(gè)對(duì)象的多個(gè)調(diào)用之間,hashCode()必須始終一致。
  2. 如果兩個(gè)對(duì)象根據(jù)equals()方法是相等的,那么它們的hashCode()必須產(chǎn)生相同的值。
  3. 如果兩個(gè)對(duì)象根據(jù)equals()方法是不相等的,那么它們的hashCode()方法不一定要產(chǎn)生不同的值,但產(chǎn)生不同的值是一個(gè)好的實(shí)踐。
  4. hashCode()方法的值應(yīng)該是根據(jù)對(duì)象的內(nèi)容計(jì)算得出的。

下面是一個(gè)簡(jiǎn)單的示例,展示了如何為一個(gè)自定義類重寫hashCode()方法:

public class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public boolean equals(Object obj) {
        if (this == obj) {
            return true;
        }
        if (obj == null || getClass() != obj.getClass()) {
            return false;
        }
        Person person = (Person) obj;
        return age == person.age && Objects.equals(name, person.name);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }
}

在這個(gè)示例中,我們首先檢查兩個(gè)Person對(duì)象是否是同一個(gè)對(duì)象(this == obj),如果是,則返回true。接下來,我們檢查傳入的對(duì)象是否為null或者它們的類是否相同,如果滿足這些條件,則返回false。然后,我們將傳入的對(duì)象強(qiáng)制轉(zhuǎn)換為Person類型,并比較它們的name和age屬性是否相等。如果它們相等,則返回true,否則返回false。

在hashCode()方法中,我們使用Java的Objects.hash()方法來生成一個(gè)基于name和age屬性的整數(shù)哈希值。這樣,如果兩個(gè)Person對(duì)象的name和age屬性相等,那么它們的hashCode()方法將產(chǎn)生相同的值,從而滿足上述hashCode()方法的要求。

0