码迷,mamicode.com
首页 > 其他好文 > 详细

SynchronizedMap 和 ConcurrentHashMap 有什么区 别?

时间:2020-06-21 13:30:40      阅读:44      评论:0      收藏:0      [点我收藏+]

标签:原来   安全   不同的   get   dma   put   进入   shm   改变   

SynchronizedMap 一次锁住整张表来保证线程安全,所以每次只能有一个线程来

访为 map。

ConcurrentHashMap 使用分段锁来保证在多线程下的性能。

ConcurrentHashMap 中则是一次锁住一个桶。ConcurrentHashMap 默认将

hash 表分为 16 个桶,诸如 get,put,remove 等常用操作只锁当前需要用到的桶。

这样,原来只能一个线程进入,现在却能同时有 16 个写线程执行,并发性能的提

升是显而易见的。

另外 ConcurrentHashMap 使用了一种不同的迭代方式。在这种迭代方式中,当

iterator 被创建后集合再发生改变就不再是抛出

ConcurrentModificationException,取而代之的是在改变时 new 新的数据从而

不影响原有的数据 ,iterator 完成后再将头指针替换为新的数据 ,这样 iterator

线程可以使用原来老的数据,而写线程也可以并发的完成改变。

SynchronizedMap 和 ConcurrentHashMap 有什么区 别?

标签:原来   安全   不同的   get   dma   put   进入   shm   改变   

原文地址:https://www.cnblogs.com/programb/p/13020297.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!