首页 > 其他 > 详细

记录ConcurrentHashMap的锁分离技术

时间:2016-03-21 19:40:16      阅读:105      评论:0      收藏:0      [点我收藏+]

技术分享

    对比上图,HashTable实现锁的方式是锁整个hash表,而ConcurrentHashMap的实现方式是锁桶(简单理解就是将整个hash表想象成一大缸水,现在将这大缸里的水分到了几个水桶里,hashTable每次都锁定这个大缸,而ConcurrentHashMap则每次只锁定其中一个 桶)。

    ConcurrentHashMap将hash表分为16个桶(默认值),诸如get,put,remove等常用操作只锁当前需要用到的桶。试想,原来 只能一个线程进入,现在却能同时16个写线程进入,并发性的提升是显而易见的。

技术分享

    值得一提的是当对ConcurrentHashMap进行remove操作时,并不是进行简单的节点删除操作,对比上图,当对ConcurrentHashMap的一个segment也就是一个桶中的节点进行remove后,例如删除节点C,C节点实际并没有被销毁,而是将C节点前面的反转并拷贝到新的链表中,C节点后面的不需要被克隆。这样来保持并发的读线程不受并发的写线程的干扰。例如现在有一个读线程读到了A节点,写线程把C删掉了,但是看上图,读线程仍然可以继续读下去;当然,如果在删除C之前读线程读到的是D,那么更不会有影响。

    根据上面所提到的ConcurrentHashMap中删除一个节点并不会立刻被读线程感受到的效果,就是传说中的弱一致性,所以ConcurrentHashMap的迭代器是弱一致性迭代器

记录ConcurrentHashMap的锁分离技术

原文:http://www.cnblogs.com/superpang/p/5302971.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!