JavaEE——多线程中的哈希表

目录

前言

在使用多线程前,我们用HashMap类来创建哈希表,但这个类线程不安全,在这篇文章,我们将介绍多线程环境的哈希表,将会讲述HashTable, HashMap, ConcurrentHashMap这三个类的主要区别。

1.HashTable

HashTable实际上就是线程安全的HashMap,两者的功能十分相似,只是HashTable会在代码一些关键地方进行加锁,比如看其中的get方法:

HashTable虽然是线程安全的类,但已经不推荐使用了,我们目前主流使用的就是接下来要提到的ConcurrentHashMap。

2.ConcurrentHashMap

ConcurrentHashMap是针对多线程场景专门优化的一个哈希表,使用方法和普通的哈希表一样。

java 复制代码
ConcurrentHashMap<Integer, String> map = new ConcurrentHashMap<>();

ConcurrentHashMap,对比于HashTable,最大的调整是针对锁的粒度进行了优化,上面可以看到,HashTale针对this进行加锁,如果进行操作,针对任何一个进程,都会对整个哈希表触发锁竞争。

而ConcurrentHashMap上,对哈希表上的每一个链表都提供了一个锁。也就是说,在针对哈希表中同一个链表的修改才会引入阻塞。这样的方案使竞争更小。

此外ConcurrentHashMap采取了原子类的放哪,基于CAS操作来针对size进行变更。

在ConcurrentHashMap扩容的时候,不会把所有键值对都搬运到更大的数组上,每次只运一部分,来确保单次搬运的速度足够快,使锁的持有时间足够短,减少开销。具体是每次进行get,put,remove等操作时,都会搬运一部分。

总结

本篇文章讲述了HashTable, HashMap, ConcurrentHashMap的主要区别,其中ConcurrentHashMap的区别最多,优化最好,需要着重进行理解。

相关推荐
_extraordinary_10 分钟前
Java JVM --- JVM内存区域划分,类加载,GC垃圾回收
java·开发语言·jvm
摸鱼的老谭36 分钟前
Java学习之旅第一季-25:一维数组
java·开发语言·数组
山猪打不过家猪43 分钟前
(一)算法
java·开发语言·算法
Momentary_SixthSense1 小时前
如何对较长的Stream链进行Debug
android·java·开发语言
JAVA学习通1 小时前
微服务项目->在线oj系统(Java-Spring)--竞赛管理
java·sql·spring
鄃鳕1 小时前
C++坑系列,C++ std::atomic 拷贝构造函数问题分析与解决方案
java·javascript·c++
木易小熙1 小时前
Guava Cache
java·spring·guava
JIngJaneIL2 小时前
图书馆自习室|基于SSM的图书馆自习室座位预约小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·图书馆自习室
毕设源码-赖学姐2 小时前
【开题答辩全过程】以 J2EE技术在在线购物分享应用中的应用为例,包含答辩的问题和答案
java·java-ee
Tadas-Gao2 小时前
微服务可观测性的“1-3-5”理想:从理论到实践的故障恢复体系
java·开发语言·微服务·云原生·架构·系统架构·可观测