Hashtable为什么效率很低

Hashtable是Java中一种比较古老的集合容器api。Hashtable实现了Map接口,具有Map接口的特性,存储key,value键值对。
在这里插入图片描述
Hashtable直接在put和get方法上面加synchronized关键字来实现线程安全。。
在这里插入图片描述
get方法
在这里插入图片描述
remove方法
在这里插入图片描述

Hashtable最大的问题是,效率极低,假设我们有两个线程t1,t2同时要执行put操作,即使t1和t2所放的位置不同,t2也要等t1put完毕才可以进行。get同理。因此效率低下
在这里插入图片描述
这也是现在Hashtable几乎没人使用的原因。
如果你要使用线程安全的map,建议你直接使用JUC包下的ConcurrentHashMap,这个对HashMap做了进一步的优化,效率比较高。它的具体原理后续再记录。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值