【JAVA】经典面试题:HashMap,Hashtable和ConcurrentHashMap三者之间的区别!!!

本篇的内容是围绕哈希表来展开的,主要是通对HashMap,Hashtable,ConcurrentHashMap三者的特点去了解这它们之间的区别以及运用场景

目录

1. HashMap

2. Hashtable

锁太粗问题:

3. 扩容机制问题

3. ConcurrentHashMap

ConcurrentHashMap做出的优化(以JDK8为例)

1. 读操作优化:

2. 锁的粗细优化:

3. 扩容机制优化(化整为零):

4.三者区别




 

1. HashMap

HashMap是继承与Map集合类的,其内部的方法是没有对线程安全进行处理的,所以HashMap是线程不安全的,在当今高并发的时代需要处理线程安全问题显然这种场景再使用HashMap就已经不太合适了。

所以针对多线程的开发环境就有了Hashtable和ConcurrentHashMap这两个线程安全的HashMap

2. Hashtable

Hashtable类做出的主要是针对HashMap类的主要的方法进行简单的加锁,用synchronized关键字对主要的方法进行修饰保证线程安全

原码:

put方法:

remove方法:

get方法:

 

优点:弥补了普通HashMap不能保证线程安全的缺点

缺点: 

锁太粗问题:

通过原码我们看到为了保证map的线程安全只是给方法直接加sy

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值