0
点赞
收藏
分享

微信扫一扫

JAVA工程师常见面试题(三):两张图搞定hashmap死循环

在觉 2021-09-21 阅读 157

hashmap在1.7及之前,为了性能考虑采用头插法,如果在扩容过程中出现多线程并行运行,可能会产生循环链表。正常单线程扩容如下:

多线程并发扩容,满足特定条件会出现循环链表如下:


如果此时再使用11,15等数值进行查询,会陷入循环链表无法找到出口指针而陷入死循环,进而导致CPU占用率100%的情况。

hashmap在1.8之后,采用了尾插法(如果链表过长会转为红黑树提升查询性能),同时在尾插法使用过程中head和tail记录头尾节点避免出现循环链表的情况。

举报

相关推荐

0 条评论