ConcurrentHashMap

HashTable,它是线程安全的,它在所有涉及到多线程操作的都加上了synchronized关键字来锁住整个table,这就意味着所有的线程都在竞争一把锁,在多线程的环境下,它是安全的,但是无疑是效率低下的。

ConcurrentHashMap:

  ConcurrentHashMap内部使用段(Segment)来表示这些不同的部分,每个段其实就是一个小的HashTable,它们有自己的锁。只要多个修改操作发生在不同的段上,它们就可以并发进行。把一个整体(ConcurrentHashMap)分成了16个段(Segment.也就是最高支持16个线程的并发修改操作。这也是在重线程场景时减小锁的粒度从而降低锁竞争的一种方案。并且代码中大多共享变量使用volatile关键字声明,目的是第一时间获取修改的内容,性能非常好。【ConcurrentHashMap内部使用分段锁来实现的,把一个ConcurrentHashMap分为16段】。

 

 

 

 

 

 

参考文章: http://www.importnew.com/26049.html

posted @ 2018-11-17 22:15  逍遥游jJ2EE  阅读(129)  评论(0编辑  收藏  举报