[JAVA修炼之路四]-集合(ConCurrentHashMap HashTable)

一、ConcurrentHashMap

1、结构图

       

2、线程安全

      注意:节点数组segsments 集合。

      节点数组初始化:采用volatile 变量 CAS保证线程安全。

      节点数组定位:unsafe getObjectVolatile 获取头节点,通过对此节点synchronized保证线程安全

3、节点数组

      为了保证数组分散均匀,采用hash值&数组大小(2的N次方-1),数组大小一定要注意 

      

4、总结

通过数组节点的分散,枷锁颗粒化,提高了性能

二、HashTable




与ConCurrentHashMap区别:这个枷锁用synchronized 枷锁整个表

另外集合位置定位,采用取模运算

三、hashMap

采用的结构与ConCurrentHashMap 相同,但是没有枷锁

后续补充其他集合

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值