HashMap的主干是一个Entry数组。Entry是HashMap的基本组成单元,每一个Entry包含一个key-value键值对。
HashMap的整体结构如下:
简单来说,HashMap由数组+链表组成的,数组是HashMap的主体,链表则是主要为了解决哈希冲突而存在的,如果定位到的数组位置不含链表(当前entry的next指向null),那么对于查找,添加等操作很快,仅需一次寻址即可;如果定位到的数组包含链表,对于添加操作,其时间复杂度为O(n),首先遍历链表,存在即覆盖,否则新增;对于查找操作来讲,仍需遍历链表,然后通过key对象的equals方法逐一比对查找。所以,性能考虑,HashMap中的链表出现越少,性能才会越好。

博客介绍了HashMap的结构,其主干是Entry数组,Entry包含key - value键值对。HashMap由数组+链表组成,数组是主体,链表用于解决哈希冲突。不含链表时查找、添加操作快,含链表时添加和查找操作需遍历,链表越少性能越好。
172万+

被折叠的 条评论
为什么被折叠?



