当前位置: 首页 > 知识库问答 >
问题:

hashCode()方法[重复]

路昆杰
2023-03-14

我需要一些帮助,从理论上更好地理解hashCode()方法。我读过(强调我的):

当对两个单独的对象调用hashCode()时(根据equals()方法,这两个对象是相等的),它将返回相同的哈希代码值。但是,如果在两个不相等的对象上调用它,它不一定会返回不同的整数值。

上述例外情况会发生在哪里?

共有2个答案

郑光济
2023-03-14
public int hashCode() {
  return 27;
}

信不信由你,但这是hashCode的有效实现,尽管它不是一种非常有效的工作方式,因为它将使用equals方法尊重合约。此实现将导致您所描述的完全相同。

hashCode用于限制要比较的案例数量。例如,如果在一所高中,您正在寻找一个学生。您只知道这个学生的姓名、性别和年龄。您是要查看所有学生,还是只查看具有该年龄和性别的学生?

对于某些数据结构,哈希代码也会这样做。在查找某个项目时,它将首先使用相同的哈希代码创建项目的子列表/集合,然后在该子列表/集合中搜索确切的项目。

哈希代码越具体,搜索效率就越高。

朱睿
2023-03-14

假设您有一个包含两个字符串字段的类,其哈希代码是通过对这两个字段的哈希代码求和来计算的。进一步假设您有一个equals,它只检查类字段值是否相等。

class Test {
    String a;
    String b;

    public Test
    
    @Override
    public int hashCode() {
        return a.hashCode() + b.hashCode();
    }


    @Override
    public boolean equals(Object o) { // simplified
         Test other = (Test)o;
         return a.equals(other.a) && b.equals(other.b);
    }
}

让我们看看非相等实例是否可以具有相同的哈希代码

Test t1 = new Test("hello", "world");
Test t2 = new Test("world", "hello");

System.out.println(t1.equals(t2));                  // false
System.out.println(t1.hashCode() == t2.hashCode()); // true

我们仍然尊重hashCode的合同吗?

每当在执行Java应用程序期间对同一对象多次调用它时,hashCode方法必须始终返回相同的整数,前提是不修改对象上的equals比较中使用的信息。从应用程序的一次执行到同一应用程序的另一次执行,该整数不需要保持一致。

好吧,是的,因为它只取决于ab,我们使用的是他们的hashCode方法,我们可以假设它尊重合同。

如果根据equals(Object)方法,两个对象相等,那么对两个对象中的每一个调用hashCode方法必须产生相同的整数结果。

的确如此

Test t1 = new Test("hello", "world");
Test t2 = new Test("hello", "world");

System.out.println(t1.equals(t2));                  // true
System.out.println(t1.hashCode() == t2.hashCode()); // true

如果两个对象根据equals(java.lang.Object)方法不相等,那么对两个对象中的每一个调用hashCode方法必须产生不同的整数结果。但是,程序员应该知道为不相等的对象生成不同的整数结果可能会提高哈希表的性能。

这就是我们一开始想要展示的。这不是要求。

 类似资料:
  • 本文向大家介绍hashCode 与 equals ?为什么重写equals时必须重写hashCode方法?相关面试题,主要包含被问及hashCode 与 equals ?为什么重写equals时必须重写hashCode方法?时的应答技巧和注意事项,需要的朋友参考一下 面试官可能会问你:“你重写过 hashcode 和 equals 么,为什么重写equals时必须重写hashCode方法?” ha

  • 本文向大家介绍重写hashCode()和equals()方法详细介绍,包括了重写hashCode()和equals()方法详细介绍的使用技巧和注意事项,需要的朋友参考一下 hashCode()和equals()方法可以说是Java完全面向对象的一大特色.它为我们的编程提供便利的同时也带来了很多危险.这篇文章我们就讨论一下如何正解理解和使用这2个方法. 如何重写equals()方法 如果你决定要重写

  • 本文向大家介绍java中重写equals()方法的同时要重写hashcode()方法(详解),包括了java中重写equals()方法的同时要重写hashcode()方法(详解)的使用技巧和注意事项,需要的朋友参考一下 object对象中的 public boolean equals(Object obj),对于任何非空引用值 x 和 y,当且仅当 x 和 y 引用同一个对象时,此方法才返回 tr

  • 问题内容: 我在为自己创建的类编写方法时遇到了麻烦。此类旨在在TreeSet中使用,因此,它实现Comparable。该类具有以下变量: 这是该方法的实现。我希望按其成本来组织这些Node结构,因此,返回简单减法的结果。 我还实现了一种方法。 说了这么多,我有几个问题: 由于实施了新方法,因此应该实施新方法吗? 如何使用这些变量实施新的hashCode ?(请注意,Matrix类型的变量矩阵已实现

  • 问题内容: 改善这个问题 来自链接: http://www.tutorialspoint.com/java/java_string_hashcode.htm Java中的hashCode和equals方法之间的关系 好的hashCode()实现 但是我不了解哈希码。 这是一个例子: 这个简单的程序给我输出: 谁能告诉我:它是如何给我的输出:? 问题答案: 字符串的 哈希码 计算如下: 使用算术,其

  • 本文向大家介绍Java实现hashCode()方法,包括了Java实现hashCode()方法的使用技巧和注意事项,需要的朋友参考一下 示例 要轻松实现对象的hashCode方法,可以使用HashCodeBuilder类。 选择字段: 使用反射: 布尔参数指示是否应使用瞬态字段。 使用反射避免某些字段: