写点什么

Java HashMap 在获得 Key 的 Hash 值的时候用的是什么算法

作者:HoneyMoose
  • 2022-12-01
    美国
  • 本文字数:1037 字

    阅读完需:约 3 分钟

Java 在 HashMap Key 的 Hash 值的时候用的的是自己 Object 中的 hashCode() 算法。


返回的结果是一个整数值。


如果你查看 JDK 的源代码的话,在 HashMap 类中会有下面的这个方法。


    public final int hashCode() {        return Objects.hashCode(key) ^ Objects.hashCode(value);    }
复制代码


通过这个方法,我们可以看到返回的值是整数。


JDK hashCode


如果我们继续跟踪代码,我们会看到在最最基础的 Object 对象中。


有下面的代码:


public int hashCode() {return J9VMInternals.fastIdentityHashCode(this);}


是不是很奇怪,为什么这个类的名字为:J9VMInternals


这是因为我们的机器装的是 IBM 的 OpenJ9 虚拟机的版本。


IBM 在这里定义了自己的获得 hashCode 的方法。


static int fastIdentityHashCode(Object anObject) {  com.ibm.jit.JITHelpers h = jitHelpers;  if (null == h) {    return identityHashCode(anObject); /* use early returns to make the JIT code faster */  }  if (h.is32Bit()) {    int ptr = h.getIntFromObject(anObject, 0L);    if ((ptr & com.ibm.oti.vm.VM.OBJECT_HEADER_HAS_BEEN_MOVED_IN_CLASS) != 0) {      if (!h.isArray(anObject)) {        int j9class = ptr & com.ibm.oti.vm.VM.J9_JAVA_CLASS_MASK;        return h.getIntFromObject(anObject, h.getBackfillOffsetFromJ9Class32(j9class));      }    }  } else {    long ptr = (com.ibm.oti.vm.VM.FJ9OBJECT_SIZE == 4) ? Integer.toUnsignedLong(h.getIntFromObject(anObject, 0L)) : h.getLongFromObject(anObject, 0L);    if ((ptr & com.ibm.oti.vm.VM.OBJECT_HEADER_HAS_BEEN_MOVED_IN_CLASS) != 0) {      if (!h.isArray(anObject)) {        long j9class = ptr & com.ibm.oti.vm.VM.J9_JAVA_CLASS_MASK;        return h.getIntFromObject(anObject, h.getBackfillOffsetFromJ9Class64(j9class));      }    }  }  return identityHashCode(anObject);}
复制代码


这个 hashCode 的方法被 IBM 提高了下,主要是看看输入的对象是不是 32 位的,如果是 32 位的,会用到 IBM 自己的方法。


否则还是使用传统的 hashCode 方法。


当然,对程序员来说,这部分的内容是透明的,程序员通常只需要知道 JDK 会在你对对象获得 hashCode 的时候返回一个整数值。


在 HashMap 插入数据的时候需要计算 Hash 值,这个方法也会被用到。


可以说这个方法是 JDK 的基础的基础了。


https://www.ossez.com/t/java-hashmap-key-hash/14227

用户头像

HoneyMoose

关注

还未添加个人签名 2021-03-06 加入

还未添加个人简介

评论

发布
暂无评论
Java HashMap 在获得 Key 的 Hash 值的时候用的是什么算法_HoneyMoose_InfoQ写作社区