ConcurrentHashMap的使用场景

先大概的说一下几个map的区别:

hashMap:读取快,插入慢,线程不安全

LinkedHashMap:读取快,插入慢

treeMap:排序

concurrentHashMap:线程安全,支持高并发的操作

当项目中的全局变量有多线程操作时需要用concurrentHashMap,若只是单线程则可以使用hashmap。

在多线程环境下使用hashMap会造成的问题:

hashMap,底层是数组+链表 结构,当两个线程同时插入需要扩容的时候,获得改map的size()大小不一样,则会报错。当有两个线程在读,第三个线程正好在对map扩容时,这两个线程就会进入死循环,cup占用率就会高。

concurrentHashMap,线程安全,读写快,底层实现是一种以空间换时间的结构,创建的时候直接分了16个segment,每个segment实际上存储的还是哈希表,写入的时候先找到对应的segment,然后对segment加锁,写完,解锁。锁segment的时候其他segment还可以继续工作。

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
ConcurrentHashMap适用于多线程环境下对全局变量进行操作的场景。与HashMap相比,ConcurrentHashMap是线程安全的,能够在高并发的情况下保证操作的安全性。它使用CAS和Synchronized机制来实现线程安全,避免了使用锁对整个集合进行同步,提高了效率。ConcurrentHashMap在更新时只会局部锁住某部分数据,而同步读取操作则是完全非阻塞的。因此,当项目中的全局变量需要被多个线程同时操作时,可以考虑使用ConcurrentHashMap来保证线程安全和高效性。 [2] 另外,与Hashtable相比,ConcurrentHashMap具有一些不同之处。Hashtable对get、put和remove操作都使用了同步操作,同步级别是针对Hashtable对象进行同步的。这意味着,如果有一个线程正在遍历Hashtable,其他线程将无法使用该集合,从而对性能和吞吐量产生影响。然而,ConcurrentHashMap只对put和remove操作使用了同步操作,而get操作并不受影响。此外,当使用Hashtable进行遍历时,如果其他线程包括本线程对Hashtable进行了更新操作,会抛出ConcurrentModificationException异常。但如果使用ConcurrentHashMap,就不用考虑这个问题了。因此,当需要在多线程环境下进行集合操作时,可以优先考虑使用ConcurrentHashMap而不是Hashtable。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [ConcurrentHashMap的作用与用法](https://blog.csdn.net/qq_37488998/article/details/109715821)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [ConcurrentHashMap使用场景](https://blog.csdn.net/NeilGY/article/details/80430201)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [ConcurrentHashMap使用场景、总结、对比Hashtable、ConcurrentSkipListMap、几种队列;J.U.C线程池、七个...](https://blog.csdn.net/qq_42722241/article/details/108147008)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值