面试精选

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

2021-01-04  本文已影响0人  布朗XD

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

正常扩容.jpg

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


并发扩容.jpg

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

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

上一篇 下一篇

猜你喜欢

热点阅读