JDK1.7的HashMap链表死循环分析

在JDK1.7及以前的版本,如果在并发环境中使用HashMap保存数据,有可能会产生死循环的问题,造成cpu的使用率飙升。产生这个问题是因为JDK1.7及以前的版本中,HashMap扩容采用的是头插入,1.8做的改进是采用尾插法,所以不会造成死循环的问题。 首先,来看1.7扩容的代码: //进行扩容时方法 void resize(int newCapacity) { Ent
相关文章
相关标签/搜索