HashMap实现原理小结

最近面试,经常被问到是否了解java HashMap的实现原理,以前确实没有关注过。回来搜了搜,并了解了实现,结果回头去看源码,居然不一样了,再查相关资料,java8为了解决在hash冲突时优化hashmap查找速度,修改了实现算法。

hashmap实现原理

所有的key-value实体会以数组的形式存储,然后通过key的hashcode计算在数组存储位置,然后通过其存储位置提取或存储实体。在计算存储位置时,会出现不同hashcode的到相同存储位置,这个时候就会出现hash冲突。

java7采用的是链表形式解决hash冲突问题,会将新加入的实体放入链表头部,其next引用指向已存在实体,当链表变得很长的时候,要提取实体的话就要遍历链表,对比key值,造成性能下降

java8为了解决这个问题,当链表长度超过指定值8的时候,会将链表转换成二叉树结构,以提高查找速度


你可能感兴趣的:(java)