温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

java的ConcurrentHashMap中为什么是synchronized而不是可重入锁

发布时间:2021-11-17 10:17:19 来源:亿速云 阅读:140 作者:iii 栏目:大数据

这篇文章主要介绍“java的ConcurrentHashMap中为什么是synchronized而不是可重入锁 ”,在日常操作中,相信很多人在java的ConcurrentHashMap中为什么是synchronized而不是可重入锁 问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java的ConcurrentHashMap中为什么是synchronized而不是可重入锁 ”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

1. 减少内存开销 
假设使用可重入锁来获得同步支持,那么每个节点都需要通过继承AQS来获得同步支持。但并不是每个节点都需要获得同步支持的,只有链表的头节点(红黑树的根节点)需要同步,这无疑带来了巨大内存浪费。 
2. 获得JVM的支持 
可重入锁毕竟是API这个级别的,后续的性能优化空间很小。 
synchronized则是JVM直接支持的,JVM能够在运行时作出相应的优化措施:锁粗化、锁消除、锁自旋等等。这就使得synchronized能够随着JDK版本的升级而不改动代码的前提下获得性能上的提升。

到此,关于“java的ConcurrentHashMap中为什么是synchronized而不是可重入锁 ”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI