concurrenthashmap多线程数据丢失
时间: 2023-10-18 19:24:40 浏览: 108
在并发编程中使用HashMap可能会导致循环引用和数据丢失的问题,而线程安全的HashTable容器由于使用了synchronnized,效率又非常低下,基于以上两个原因便有了ConcurrentHashMap。ConcurrentHashMap使用了分段锁技术来解决线程安全问题。具体来说,它将数据分成一段一段地存储,并为每一段数据配一把锁。当一个线程占用锁访问其中一个段数据时,其他段的数据也能被其他线程访问,从而避免了锁竞争,提高了并发访问效率。这种锁分段技术使得ConcurrentHashMap可以在多线程环境下安全地进行数据操作,减少了数据丢失的可能性。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [解决HashMap线程不安全之ConcurrentHashMap源码剖析(jdk1.7)](https://blog.csdn.net/m0_60907200/article/details/123456677)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
阅读全文