Hash算法以及HashMap的一些小知识

Posted freakkkkk

tags:

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

     Hash算法(转至https://www.cnblogs.com/xiohao/p/4389672.html

      散列表,又叫哈希表,它是基于快速存取的角度设计的,也是一种典型的“空间换时间”的做法。顾名思义,该数据结构可以理解为一个线性表,但是其中的元素不是紧密排列的,而是可能存在空隙。

      散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构。也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度。这个映射函数叫做散列函数,存放记录的数组叫做散列表。比如我们存储70个元素,但我们可能为这70个元素申请了100个元素的空间。70/100=0.7,这个数字称为负载因子。我们之所以这样做,也 是为了“快速存取”的目的。我们基于一种结果尽可能随机平均分布的固定函数H为每个元素安排存储位置,这样就可以避免遍历性质的线性搜索,以达到快速存取。但是由于此随机性,也必然导致一个问题就是冲突。所谓冲突,即两个元素通过散列函数H得到的地址相同,那么这两个元素称为“同义词”。这类似于70个人去一个有100个椅子的饭店吃饭。散列函数的计算结果是一个存储单位地址,每个存储单位称为“桶”。设一个散列表有m个桶,则散列函数的值域应为[0,m-1]。

     HashMap请看https://www.cnblogs.com/chenssy/p/3521565.html,其中一些问题i <<= 2;//i = i<<2 i等于i乘以2的2次方,>>就是相除了。

以上是关于Hash算法以及HashMap的一些小知识的主要内容,如果未能解决你的问题,请参考以下文章

腾讯算法高级研究员陈松坚:智能问答技术及其应用

Java面试小短文HashMap是如何解决Hash冲突的?

Java面试小短文HashMap是如何解决Hash冲突的?

Java面试小短文HashMap是如何解决Hash冲突的?

Java面试小短文HashMap是如何解决Hash冲突的?

HashMap源码分析和面试准备