当前位置:网站首页 > 技术博客 > 正文

.hashcode()



hashCode方法用来返回对象的哈希值,提供该方法是为了支持哈希表,例如HashMap,HashTable等,在Object类中的代码如下:

 
  

这是一个native声明的本地方法,返回一个int型的整数。由于在Object中,因此每个对象都有一个默认的哈希值。

在openjdk8根路径/hotspot/src/share/vm/runtime路径下的synchronizer.cpp文件中,有生成哈希值的代码:

 
  

源码中的hashCode其实是JVM启动的一个参数,每一个分支对应一个生成策略,通过可以切换hashCode的生成策略。
下面验证第2种生成策略,用软件输入参数,可以看到输出结果正是1,从而进一步验证了上面的源码。
在这里插入图片描述

在这里插入图片描述

hashCode()和equals()用来标识对象,两个方法协同工作用来判断两个对象是否相等。对象通过调用 Object.hashCode()生成哈希值,由于不可避免地会存在哈希值冲突的情况 因此hashCode 相同时 还需要再调用 equals 进行一次值的比较,但是若hashCode不同,将直接判定两个对象不同,跳过 equals ,这加快了冲突处理效率。 Object 类定义中对 hashCode和 equals 要求如下:

  • 如果两个对象的equals的结果是相等的,则两个对象的 hashCode 的返回结果也必须是相同的。
  • 任何时候重写equals,都必须同时重写hashCode

下面看一个小例子:

 
  

我们将Person类的实例作为key,value为这个对象的考试成绩。我们期望通过获取该对象的考试成绩,但上面代码的输出结果为。原因就在于Person类中没有覆盖方法,从而导致两个相等的实例具有不同的哈希值。中get()的核心代码如下

 
  
 
  

这样就能解决问题,但是这个运行速度慢一些,因为它们会引发数组的创建,以便传入数目可变的参数, 如果参数中有基本类型,还需要装箱和拆箱 ,建议只将这类散列函数用于不太注重性能的情况

Java为许多常用的数据类型重写了方法,比如,,等。比如在Integer类中哈希值就是其int类型的数据。

 
  

具体细节去JDK源码中看看吧😊

版权声明


相关文章:

  • c 程序视频教程2025-09-02 21:30:05
  • oracle imp导入dmp文件命令2025-09-02 21:30:05
  • 灰度发布方案2025-09-02 21:30:05
  • 多层感知机2025-09-02 21:30:05
  • getchar在c语言中怎么用2025-09-02 21:30:05
  • 服务器硬件坏了怎么快速处理2025-09-02 21:30:05
  • 黑夜汉化组咕噜咕噜停止机2025-09-02 21:30:05
  • linux中fork()函数详解(原创!!实例讲解)2025-09-02 21:30:05
  • 乐高ev3编程入门2025-09-02 21:30:05
  • 数据库设计详细设计2025-09-02 21:30:05