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


这篇文章主要介绍“java的ConcurrentHashMap中为什么是synchronized而不是可重入锁 ”,在日常操作中,相信很多人在java的ConcurrentHashMap中为什么是synchronized而不是可重入锁 问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java的ConcurrentHashMap中为什么是synchronized而不是可重入锁 ”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!1. 减少内存开销
假设使用可重入锁来获 香港云主机得同步支持,那么每个节点都需要通过继承AQS来获得同步支持。但并不是每个节点都需要获得同步支持的,只有链表的头节点(红黑树的根节点)需要同步,这无疑带来了巨大内存浪费。
2. 获得JVM的支持
可重入锁毕竟是API这个级别的,后续的性能优化空间很小。
synchronized则是JVM直接支持的,JVM能够在运行时作出相应的优化措施:锁粗化、锁消除、锁自旋等等。这就使得synchronized能够随着JDK版本的升级而不改动代码的前提下获得性能上的提升。
到此,关于“java的ConcurrentHashMap中为什么是synchronized而不是可重入锁 ”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注开发云网站,小编会继续努力为大家带来更多实用的文章!

相关推荐: PHP选项参数相关的函数有哪些

这篇文章将为大家详细讲解有关PHP选项参数相关的函数有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。关于 PHP 的配置,我们大多数情况下都是去查看 php.ini 文件或者通过命令行来查询某些信息,其实,…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 08/16 16:57
下一篇 08/16 16:57

相关推荐