HashMap底层及使用个人理解

Posted 爱萌妹的大叔

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了HashMap底层及使用个人理解相关的知识,希望对你有一定的参考价值。

HashMap原理
  HashMap底层采用数组结合链表形式保存,数组中保存的数据Entry,它有四个属性(key,value,next,hashcode)。我们都知道HashMap采用键值对保存数据。
实现流程如下,先用本地方法获取key的hashcode,再用该数据的hash值与数组长度-1,采用按位与获得数组的下标,便可以获取该键key所对应的值。

HashMap冲突(jdk中的实现):
  HashMap虽然可以很好的保存,查询数据,但是可能会发生多个key对应一个hashcode,其采用链表的形式保存这样的数据。
  实现如下:当发生HashMap冲突时,先将新值替换原有的值value。然后将新值Entry中的next指向旧值对应的地址。

HashMap优化使用:
  HashMap子类LinkedHashMap,继承了HashMap性能优点,在其基础上进行了改进,增加了排序功能,排序功能有插入时排序和最近访问排序。
  HashMap兄弟类TreeMap,TreeMap额外实现了SortedMap 接口,不仅可以对键进行排序,还可以对其元素便可以进行排序。就其性能来说,采用红黑树排序算法,性能很好。

个人推荐:如果要对Map进行排序,可以直接使用该TreeMap 而不是在程序中使用排序算法。重复造轮子,增加开发成本,也可能会成为以后开发的瓶颈。

以上是关于HashMap底层及使用个人理解的主要内容,如果未能解决你的问题,请参考以下文章

[JavaSE 源码分析] 关于HashMap的个人理解

双列集合框架:Map(个人理解)

对于Windows安装系统的一些个人理解

setdefault函数的用法及个人理解

setdefault函数的用法及个人理解

面试突击15:说一下HashMap底层实现?及元素添加流程?