jdk1.7和jdk1.8下CurrentHashMap的对比

jdk1.7和jdk1.8下CurrentHashMap的对比,第1张

jdk1.7版本
1、CurrentHashMap解决线程安全问题,采用分段锁策略,将一个HashMap分割成segment数组,segment可以看成一个HashMap,不同点是segment继承ReentrantLock,在 *** 作时给segment赋予对象锁,保证线程安全。其中HashEntry和HashMap也类似,只不过HashEntry的value和next采用volatile修饰,保证多线程的可见性。

2、当并发严重,冲突链表太长时查询性能会很差。

jdk1.8版本

1、将segment分段锁变为了CAS+synchronized,实现复杂了很多。

2、解决了jdk1.7冲突链表过长导致查询很差的问题,当链表长度超过8时就会将链表变成红黑树,大幅提高查询效率。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/917004.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-16
下一篇2022-05-16

发表评论

登录后才能评论

评论列表(0条)

    保存