网站救助计划
1.为阅读体验,本站无任何广告,也无任何盈利方法,站长一直在用爱发电,现濒临倒闭,希望有能力的同学能帮忙分担服务器成本
2.捐助10元及以上同学,可添加站长微信lurenzhang888,备注捐助,网站倒闭后可联系站长领取本站pdf内容
3.若网站能存活下来,后续将会持续更新内容
JDK1.7
在JDK1.7中,ConcurrentHashMap
采用Segment
数组 + HashEntry
数组的方式进行实现。Segment
实现了ReentrantLock
,所以Segment
有锁的性质,HashEntry
用于存储键值对。一个ConcurrentHashMap
包含着一个Segment
数组,一个Segment
包含着一个HashEntry
数组,HashEntry
是一个链表结构,如果要获取HashEntry
中的元素,要先获得Segment
的锁。
JDK1.8
在JDK1.8中,不在是Segment
+HashEntry
的结构了,而是和HashMap
类似的结构,Node数组+链表/红黑树,采用CAS
+synchronized
来保证线程安全。当链表长度大于8,链表转化为红黑树。在JDK1.8中synchronized
只锁链表或红黑树的头节点,是一种相比于segment
更为细粒度的锁,锁的竞争变小,所以效率更高。
总结一下:
- JDK1.7底层是
ReentrantLock
+Segment
+HashEntry
,JDK1.8底层是synchronized
+CAS
+链表/红黑树 - JDK1.7采用的是分段锁,同时锁住几个
HashEntry
,JDK1.8锁的是Node节点,只要没有发生哈希冲突,就不会产生锁的竞争。所以JDK1.8相比于JDK1.7提供了一种粒度更小的锁,减少了锁的竞争,提高了ConcurrentHashMap
的并发能力。
本站链接:https://www.mianshi.online,如需勘误或投稿,请联系微信:lurenzhang888
点击面试手册,获取本站面试手册PDF完整版