我们可以看到,在 hashmap 中要找到某个元素,需要根据 key 的 hash 值来求得对应数组中的位置。如何计算这个位置就是 hash 算法。

前面说过,hashmap 的数据结构是数组和链表的结合,所以我们当然希望这个 hashmap 里面的元素位置尽量的分布均匀些,尽量使得每个位置上的元素数量只有一个。那么当我们用 hash 算法求得这个位置的时候,马上就可以知道对应位置的元素就是我们要的,而不用再去遍历链表。 所以,我们首先想到的就是把 hashcode 对数组长度取模运算。这样一来,元素的分布相对来说是比较均匀的。

但是“模”运算的消耗还是比较大的,能不能找一种更快速、消耗更小的方式?我们来看看 JDK1.8 源码是怎么做的。

static final int hash(Object key) {if (key == null){return 0;}int h;h = key.hashCode();返回散列值也就是hashcode// ^ :按位异或// >>>:无符号右移,忽略符号位,空位都以0补齐//其中n是数组的长度,即Map的数组部分初始化长度return (n-1)&(h ^ (h >>> 16));
}

简单来说就是:

  • 高16 bit 不变,低16 bit 和高16 bit 做了一个异或(得到的 hashcode 转化为32位二进制,前16位和后16位低16 bit和高16 bit做了一个异或)
  • (n·1) & hash = -> 得到下标

HashMap中hash函数怎么是实现的?相关推荐

  1. HashMap中hash(Object key)原理(hashcode >>> 16)

    大家都知道(jdk1.8)HashMap中计算数组下标是HashMap的核心算法.小编今天在看HashMap源码中看到了hash(Object key)方法百思不得其解.小编问百度,查找相关博客,甚至 ...

  2. hash算法_阿里面试官:讲一下Hashmap中hash算法!

    注:本文内容全部基于jdk8讲述. 相信很多人都知道,在JDK8中,HashMap的容量总是2的n次幂,那么这么设计的目的究竟是什么呢?我可不可以将默认的初始容量从16改成20呢,扩容的时候我可不可以 ...

  3. HashMap中hash(Object key)原理,为什么(hashcode >>> 16)。

    未经本人容许,禁止转载 大家都知道(jdk1.8)HashMap中计算数组下标是HashMap的核心算法.小编今天在看HashMap源码中看到了hash(Object key)方法百思不得其解.小编问 ...

  4. HashMap 中 hash 冲突的解决方法及原理分析

    我们最先衰老的不是容貌,而是不顾一切的闯劲.有时候,要敢于背上超出自己预料的包袱,真的努力后,你会发现自己要比想象的优秀很多. HashMap冲突的解决方法比较考验一个开发者解决问题的能力. 在Jav ...

  5. Java中hashCode()方法以及HashMap()中hash()方法

    Java的Object类中有一个hashCode()方法: public final native Class<?> getClass(); public native int hashC ...

  6. hashmap中的key是有序的么_HashMap?面试?我是谁?我在哪

    (给ImportNew加星标,提高Java技能) 转自:卓庆森 https://www.cnblogs.com/zhuoqingsen/p/8577646.html 现在是晚上11点了,学校屠猪馆的自 ...

  7. java基础篇 - HashMap 理解Hash碰撞

    HashMap是大家都在用,面试的时候也经常会被考的考点,在这篇文章中说下HashMap的hash碰撞和减轻碰撞的优化. 1.什么是hash碰撞 在解释Hash碰撞之前先说一下hashmap的存储结构 ...

  8. HashMap中的hash函数

    在写一个HashSet时候有个需求,是判断HashSet中是否已经存在对象,存在则取出,不存在则add添加.HashSet也是通过HashMap实现,只用了HashMap的key,value都存储一个 ...

  9. Hash(哈希)简述 —— Hash函数、Hash值、HashTable、HashMap

    总览 - Hash(哈希.散列) Hash是一种 散列函数或方法 的统称. · 该方法就是:把任意长度的输入通过散列算法变换成固定长度的输出,该输出就是散列值.-- (散列方法) · 这种转换是一种压 ...

最新文章

  1. Linux 安装 TigerVNC
  2. 电子计算机工程学,计算机工程
  3. [caffe解读] caffe从数学公式到代码实现5-caffe中的卷积
  4. 【HDOJ】3006 The Number of set
  5. C++工作笔记-WM_KEYFIRST和WM_KEYDOWN的用法
  6. Netty与mina的比较
  7. 学习template算法以及改进(一)
  8. js放到head中失效的原因与解决方法
  9. 【React】添加新组件
  10. HTML5 之 FileReader(图片上传)
  11. Django media 配置
  12. 安卓java游戏模拟器_java游戏模拟器安卓版下载
  13. AADL Inspector 故障树安全分析模块
  14. Python Flask 微信验证
  15. python-igraph基本用法(一)
  16. envi反演水质参数_遥感干旱反演方法汇总
  17. visual studio code远程连接服务器
  18. 数据结构---王道408
  19. 搬家准备哪些东西搬家怎么打包?搬家攻略赶紧收藏!
  20. C++判断一个日期是某一年的多少天(含闰年判断)

热门文章

  1. 在业务系统中寻求技术含量
  2. 基于CDN边缘网络智能优化图片和视频
  3. TikTok面临用户流失、苹果iOS14公测、无代码定义下一代软件等| Decode the Week
  4. 如何使用下一代编码技术提升流媒体体验
  5. 【重磅】中国AVS2标准被国际超高清联盟UHD Forum采纳,推荐给全球视频服务商
  6. webrtc一对一通话
  7. GitHub--创建新的分支
  8. Scala _11SparkWordCountscala语言java语言
  9. leetcode 372. Super Pow | 372. 超级次方(快速幂)
  10. 操作系统:第二章 进程管理1 - 进程、线程