为什么Vector、HasTable是线程安全的?ConcurrentHashMap 分段锁?

本文深入探讨了Java集合框架中的Vector和HashTable为何是线程安全的,主要原因是它们对关键操作进行了同步处理。尽管这确保了安全性,但也降低了多线程环境下的效率。为了解决这个问题,从JDK 1.5开始引入了ConcurrentHashMap,它采用了分段锁的概念,将数据分为多个段并分别加锁,提高了并发性能。ConcurrentHashMap由Segment数组和HashEntry数组构成,每个Segment相当于一个可重入锁,守护其对应HashEntry数组的元素,从而实现高效并发的键值存储。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Vector源码

add方法:

get方法:

 

HashTable源码类

put方法:

get方法:

他们都有一个共同点都加了同步函数,来保证线程安全

因为HashTable的读写都是同步的,所以多线程效率非常低,jdk1.5后出现了他的替代品

ConcurrentHashMap 分段锁

ConcurrentHashMap,它内部细分了若干个小的 HashMap,称之为段(Segment)。 默认情况下一个 Concur

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值