
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时就会将链表变成红黑树,大幅提高查询效率。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)