HashTable,HashMap和ConCunrrentHashMap比较

原作者:Thomson_Yang
原链接:https://www.jianshu.com/p/0adfae3c99c1
 

HashMap和HashTable在使用上基本一致(API)

但HashTable是线程安全的,在实现的时候所有方法都用synchronized关键字修饰

ConCurrentHashMap和HashMap的使用也是一致的,同时也是线程安全的。但和HashTable不同的是,它的性能会更好一些。

HashTable使用synchronized关键字,是给对象加锁,锁住的是对象整体,当HashTable大到一定程度,性能会急剧下降,因为迭代时需要被锁定很长的时间。而ConCurrentHashMap对这个问题进行了优化,引入了分割(Segment)。可以理解为把一个大的Map拆分为N个小的HashTable。在Segment内部基于lock机制保证线程安全,锁住的不是整个Map。

所以说HashTable基本已经被淘汰了



 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值