看了这个就懂HashMap了.docxVIP

  • 2
  • 0
  • 约 5页
  • 2017-01-05 发布于重庆
  • 举报
看了这个就懂HashMap了

Hashmap是一种非常常用的、应用广泛的数据类型:1、hashmap的数据结构 要知道hashmap是什么,首先要搞清楚它的数据结构,在java编程语言中,最基本的结构就是两种,一个是数组,另外一个是模拟指针(引用),所有的数据结构都可以用这两个基本结构来构造的,hashmap也不例外。Hashmap实际上是一个数组和链表的结合体(在数据结构中,一般称之为“链表散列“),请看下图(横排表示数组,纵排表示数组元素【实际上是一个链表】)。??从图中我们可以看到一个hashmap就是一个数组结构,当新建一个hashmap的时候,就会初始化一个数组。我们来看看java代码:?Java代码 /** ??????*?The?table,?resized?as?necessary.?Length?MUST?Always?be?a?power?of?two. ??????*??FIXME?这里需要注意这句话,至于原因后面会讲到 ??????*/??????transient?Entry[]?table;??/** * The table, resized as necessary. Length MUST Always be a power of two. * FIXME 这里需要注意这句话,至于原因后面会讲到 */ transient Entry[] table;?Java代码 static?class?EntryK,V?implements?Map.EntryK,V?{ ??????????final?K?key; ??????????V?value; ??????????final?int?hash; ??????????EntryK,V?next; ??.......... ??}??static class EntryK,V implements Map.EntryK,V { final K key; V value; final int hash; EntryK,V next;..........}上面的Entry就是数组中的元素,它持有一个指向下一个元素的引用,这就构成了链表。??????当我们往hashmap中put元素的时候,先根据key的hash值得到这个元素在数组中的位置(即下标),然后就可以把这个元素放到对应的位置中了。如果这个元素所在的位子上已经存放有其他元素了,那么在同一个位子上的元素将以链表的形式存放,新加入的放在链头,最先加入的放在链尾。从hashmap中get元素时,首先计算key的hashcode,找到数组中对应位置的某一元素,然后通过key的equals方法在对应位置的链表中找到需要的元素。从这里我们可以想象得到,如果每个位置上的链表只有一个元素,那么hashmap的get效率将是最高的,但是理想总是美好的,现实总是有困难需要我们去克服,哈哈~ 2、hash算法 我们可以看到在hashmap中要找到某个元素,需要根据key的hash值来求得对应数组中的位置。如何计算这个位置就是hash算法。前面说过hashmap的数据结构是数组和链表的结合,所以我们当然希望这个hashmap里面的元素位置尽量的分布均匀些,尽量使得每个位置上的元素数量只有一个,那么当我们用hash算法求得这个位置的时候,马上就可以知道对应位置的元素就是我们要的,而不用再去遍历链表。 所以我们首先想到的就是把hashcode对数组长度取模运算,这样一来,元素的分布相对来说是比较均匀的。但是,“模”运算的消耗还是比较大的,能不能找一种更快速,消耗更小的方式那?java中时这样做的,Java代码 static?int?indexFor(int?h,?int?length)?{ ?????????return?h??(length-1); ?????}?? static int indexFor(int h, int length) { return h (length-1); }首先算得key得hashcode值,然后跟数组的长度-1做一次“与”运算()。看上去很简单,其实比较有玄机。比如数组的长度是2的4次方,那么hashcode就会和2的4次方-1做“与”运算。很多人都有这个疑问,为什么hashmap的数组初始化大小都是2的次方大小时,hashmap的效率最高,我以2的4次方举例,来解释一下为什么数组大小为2的幂时hashmap访问的性能最高。 ???????? 看下图,左边两组是数组长度为16(2的4次方),右边两组是数组长度为15。两组的hashcode均为8和9,但是很明显,当它们和1110“与”的时候,产生了相同的结果,也

文档评论(0)

1亿VIP精品文档

相关文档