HashMap 学习 (JDK8)

Posted heben

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了HashMap 学习 (JDK8)相关的知识,希望对你有一定的参考价值。

1.hashmap中hash函数的实现中,异或运算操作的结果是什么,为什么要做这样的异或运算

    static final int hash(Object key) {
        int h;
        return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
    }

假设h是 1000010001110001000001111000000,h>>>16的结果就是一个新的32位数,高16位为0,低16位为h的高16位,这个新数记为q,h^q的结果记为r,以方便描述

由于异或运算的特点,r的高16位就是h的高16位,r的低16位,就是h的低16位和h的高16位进行异或运算的结果

 

以上是关于HashMap 学习 (JDK8)的主要内容,如果未能解决你的问题,请参考以下文章

说一下HashMap的实现原理?

jdk8 hashmap 链表resize 源码分析

2JDK8中的HashMap实现原理及源码分析

JDK8源码解读:HashMap

JDK8源码解析 -- HashMap

JDK8下的HashMap有什么特别之处?