首页 > 编程语言 >Java基础——HashMap 的长度为什么是 2 的幂次方

Java基础——HashMap 的长度为什么是 2 的幂次方

时间:2023-03-09 22:35:31浏览次数:54  
标签:hash HashMap 42 哈希 长度 次方 Java

HashMap 的长度为什么是 2 的幂次方

为了能让 HashMap 存取高效,尽量较少碰撞,也就是要尽量把数据分配均匀。我们上面也讲到了过了,Hash 值的范围值-2147483648 到 2147483647,前后加起来大概 40 亿的映射空间,只要哈希函数映射得比较均匀松散,一般应用是很难出现碰撞的。但问题是一个 40 亿长度的数组,内存是放不下的。所以这个散列值是不能直接拿来用的。用之前还要先做对数组的长度取模运算,得到的余数才能用来要存放的位置也就是对应的数组下标。这个数组下标的计算方法是“ (n - 1) & hash”。(n 代表数组长度)。这也就解释了 HashMap 的长度为什么是 2 的幂次方。

这个算法应该如何设计呢?

我们首先可能会想到采用%取余的操作来实现。但是,重点来了:“取余(%)操作中如果除数是 2 的幂次则等价于与其除数减一的与(&)操作(也就是说 hash%length==hash&(length-1)的前提是 length 是 2 的 n 次方;)。” 并且 采用二进制位操作 &,相对于%能够提高运算效率,这就解释了 HashMap 的长度为什么是 2 的幂次方

 

在Java中,表达式 (n - 1) & hash 常用于计算哈希表中键的索引。其中 n 表示哈希表的大小(通常为2的幂),hash 表示键的哈希码。

表达式 (n - 1) & hash 计算了 n - 1 和 hash 的按位与。由于 n 是2的幂,所以 n - 1 的所有低位都被设置为1。当这个值与 hash 进行按位与时,它实际上是将 hash 除以 n 后取余数,这样可以确保结果索引在界内(介于0和n-1之间)。

下面是一个例子:

int n = 16; // 哈希表大小(2的幂)
int hash = 42; // 键的哈希码
int index = (n - 1) & hash; // 哈希表中键的索引

在这个例子中,(n - 1) & hash 计算了 (16 - 1) & 42, 相当于 15 & 42. 在二进制中,相当于:

   1111 (15)
&101010 (42)
-------
   1010 (10)

因此,在这种情况下,在大小为16的哈希表中,具有哈希码为42的键的索引将是10。

标签:hash,HashMap,42,哈希,长度,次方,Java
From: https://www.cnblogs.com/fulaien/p/17201722.html

相关文章

  • java8新特性/函数式编程/lamda/stream流
    新特性简介   java8内置的四大核心函数式接口          其他接口  方法引用               构造使用......
  • Java实现对象空属性(空字符串)转null
    @Slf4jpublicclassConvertUtils{/***@Description主要解决查询时前端传参为空值("")*BeanUtils.copyProperties会把空值带入目标对象中*......
  • Java数据类型转换
    类型转换由于Java是强类型语言,所以要进行有些运算的时候需要用到类型转换。低 ---------------------------------> 高byte,short,char->int->long->float->doub......
  • Java Set Summary
    JavaSetSummary一、概要Set6个类名since线程安全elementnull特点Set1.2HashSet1.2NoYes基于HashMap实现TreeSet1.2NoNo基于TreeMa......
  • [java-project-gl]接口幂等性
    接口幂等性一、什么是幂等性接口幂等性就是用户对于同一操作发起的一次请求或者多次请求的结果是一致的,不会因为多次点击而产生了副作用;比如说支付场景,用户购买了商品支......
  • [java-project-gl]分布式缓存
    分布式缓存缓存常见的问题缓存穿透缓存和数据库中都没有的数据,而用户不断发起请求,导致数据压力过大,甚至击垮数据库比如黑客会对你的系统进行攻击,拿一个不存在的id去查......
  • [java-Spring]-Spring Boot入门基本操作
    目录一、SpringBoot入门1、SpringBoot简介2、微服务3、环境准备1、MAVEN设置;2、IDEA设置4、SpringBootHelloWorld1、创建一个maven工程;(jar)2、导入springboot相关的......
  • [java-project-gl]购物车
    一、购物车1、购物车需求1、需求描述:用户可以在登录状态下将商品添加到购物车【用户购物车/在线购物车】放入数据库mongodh放入redis(采用)登录以后,会将临时购物......
  • [java]-[cloud]openfeigon底层使用的什么传输协议,执行流程是怎样的
    1.1Feign概述这篇文章主要讲述如何通过Feign去消费服务,以及Feign的实现原理的解析。Feign是Netflix开发的声明式、模板化的HTTP客户端,Feign可以帮助我们更快捷、优雅地......
  • [java]-[cloud]-Spring Cloud Alibaba Sentinel
    1、整合Sentinel1、pom.xml安装依赖<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-s......