hashcode和hash算法的实现原理是什么

技术hashcode和hash算法的实现原理是什么本篇文章给大家分享的是有关hashcode和hash算法的实现原理是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一

本文是关于hashcode和hash算法的实现原理。边肖觉得很实用,所以想分享给大家学习。希望大家看完这篇文章能有所收获。我不多说。让我们和边肖一起看看。

哈希算法如何实现密钥的均匀分散?

在JDK,Object的hashcode方法是一个局部方法,也就是用C语言或者C实现,直接返回对象的内存地址。

我们没有重写hashCode方法,所以在HashMap中使用了对象的内存地址,所以它一定是不同的。

字符串类型如何覆盖hashCode方法?

/**

*字符串的char数组的个数每次乘以31,然后叠加,最后返回。因此,每个不同字符串返回的hashCode肯定是不同的。

*/

publishingtashcode(){ 0

inth=hash

if(h==0 value . length 0){ 0

char val[]=值;

for(inti=0;ivalue.lengthI){ 0

h=31 * h val[I];

}

hash=h;

}

returnh

}

那么为什么要用31呢?

冲突的风险很高。

31 * i==(i 5) - i

63溢出的风险更大。

15块怎么样?

00-1010,以便更好地统一哈希表的下标。

static finalinthash(Objectkey){ 0

inth

return(key==null)?0:(h=key.hashcode())^(h16);

}

也就是说,计算出的int类型32位(4字节),而不是低16位,将高16位移过去,以便尽可能均匀地分布它们。

也就是hashcode和hash算法的实现原理是什么。边肖认为,一些知识点可能会在我们的日常工作中看到或使用。我希望你能通过这篇文章学到更多的知识。更多详情请关注行业资讯频道。

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/37104.html

(0)

相关推荐

  • 抖音刷粉神器电脑版-抖音刷1w赞多少费用

    技术抖音刷粉神器电脑版-抖音刷1w赞多少费用抖音刷粉神器电脑版-抖音刷1w赞多少费用
    第二:虽然最起初是15秒的视频,但还是需要用心去制作和拍摄视频的。
    免费刷颤音粉丝代刷网
    宣传。这里就不多说了,你在这里看到这篇文章,

    测评 2021年11月13日
  • 【上接 9 年前的一篇文章】动态创建控件的一个坑和解决方案

    技术【上接 9 年前的一篇文章】动态创建控件的一个坑和解决方案 【上接 9 年前的一篇文章】动态创建控件的一个坑和解决方案提出问题
    昨天一位网友提出了这么一个问题:动态创建Disabled的文本输入框,

    礼包 2021年11月1日
  • ubuntu中VETH虚拟接口的示例分析

    技术ubuntu中VETH虚拟接口的示例分析这篇文章将为大家详细讲解有关ubuntu中VETH虚拟接口的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简介virtual eth

    攻略 2021年11月17日
  • 复杂的英语,高中英语复杂句子成分分析例句

    技术复杂的英语,高中英语复杂句子成分分析例句并列句中两个分句又内含从句的话,那就成为一种更加复杂的并列复合句复杂的英语。例句:While the men worked to stregthen the dam ,the

    生活 2021年10月20日
  • 如何理解HBase中的HFile合并过程

    技术如何理解HBase中的HFile合并过程如何理解HBase中的HFile合并过程,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。HBase 根据合并规

    攻略 2021年11月23日
  • rtthread的使用分析

    技术rtthread的使用分析这篇文章将为大家详细讲解有关rtthread的使用分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。RT-Thread 中,实际上线程并不存

    攻略 2021年11月10日