跳至主要內容
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?

4563博客

全新的繁體中文 WordPress 網站
  • 首頁
  • 1.8 Hashmap 里的 hash 方法是什么意思呢
未分類
15 11 月 2020

1.8 Hashmap 里的 hash 方法是什么意思呢

1.8 Hashmap 里的 hash 方法是什么意思呢

資深大佬 : rqxiao 6

return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);

网上说是让这个 key 可以更加分散?

让原本的 hashcode 和 原本 hashcode 无符号右移 16 位 进行一次异或

大佬有話說 (3)

  • 資深大佬 : kerb15

    扰动函数,将高位和地位做异或,主要是为了让所有二进制位都能进来参与运算,增加随机性,使得散列的效果更好

  • 資深大佬 : SoloCompany

    因为桶的数量通常不会超过 65536, 异或一下减少高位信息熵的浪费

  • 資深大佬 : AllanAG

    在这个方法中将 key 的 hashcode 右移 16 位,然后按位异或。异或算法是相同为 0,不同为 1 。
    右移 16 位以后,原来的高 16 位就到了低 16 位上,再与原来的数异或,就相当于高 16 位与低 16 位异或。
    因此 hash 算法的作用就是高 16 位不变,低 16 位和高 16 位做异或。

文章導覽

上一篇文章
下一篇文章

AD

其他操作

  • 登入
  • 訂閱網站內容的資訊提供
  • 訂閱留言的資訊提供
  • WordPress.org 台灣繁體中文

51la

4563博客

全新的繁體中文 WordPress 網站
返回頂端
本站採用 WordPress 建置 | 佈景主題採用 GretaThemes 所設計的 Memory
4563博客
  • Hostloc 空間訪問刷分
  • 售賣場
  • 廣告位
  • 賣站?
在這裡新增小工具