两个对象值相同(x.equals(y) == true),但却可有不同的hash code

当我们使用 Java 的 hashCode() 方法时,该方法将返回与该对象相关的一个整数值。hash code 用于在哈希表等数据结构中确定对象的位置,以提高查找效率。当我们使用 equals() 方法比较两个对象时,如果 equals() 返回 true,则可以认为这两个对象的值相等。

然而,有时候两个对象值相同,但它们的 hash code 却不同。这是因为 hash code 与对象的值是两个独立的概念。

为了更好地理解这个问题,我们可以看下面这个例子:

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

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

    @Override
    public boolean equals(Object obj) {
        if (obj == this) return true;
        if (!(obj instanceof Example)) return false;
        Example example = (Example) obj;
        return example.name.equals(this.name) && example.age == this.age;
    }

    @Override
    public int hashCode() {
        return name.hashCode() + age;
    }
}

在上面的例子中,我们自定义了一个类 Example,它有两个成员变量 name 和 age。我们重写了 equals() 和 hashCode() 方法来比较两个 Example 对象是否相等。equals() 方法通过比较 name 和 age 成员变量的值来判断对象是否相等。hashCode() 方法使用成员变量 name 的 hashCode() 方法和 age 的整数值的和来计算 hash code。

如果我们创建两个 Example 对象,它们的值相等,如下所示:

Example example1 = new Example("John", 30);
Example example2 = new Example("John", 30);

那么,使用 equals() 方法比较它们时,将返回 true。因为这两个对象的 name 和 age 成员变量的值相同。但是,如果我们使用 hashCode() 方法比较它们的 hash code,我们会发现它们的 hash code 不同,如下所示:

System.out.println(example1.hashCode());  // 2103
System.out.println(example2.hashCode());  // 2104

这是因为 hashCode() 方法的计算方式不同,即使两个对象的值相同,它们的 hash code 也可以不同。在这种情况下,可能会出现一些问题,例如当将对象放入哈希表等数据结构中时,可能会出现意外的结果。因此,我们需要注意 equals() 和 hashCode() 方法的实现,以确保它们在比较对象相等性时具有一致性。

猜你喜欢

转载自blog.csdn.net/wssc63262/article/details/129976550