java 高并发中volatile的实现原理

摘要: 在多线程并发编程中synchronized和Volatile都扮演着重要的角色,Volatile是轻量级的synchronized,它在多处理器开发中保证了共享变量的“可见性”。可见性的意思是当一个线程修改一个共享变量时,另外一个线程能读到这个修改的值。它在某些情况下比synchronized的开销更小
1. 定义:
java编程语言允许线程访问共享变量,为了确保共享变量能被准确和一致的更新,线程应该确保通过排他锁单独获得这个变量。Java语言提供了volatile,在某些情况下比锁更加方便。如果一个字段被声明成volatile,java线程内存模型确保所有线程看到这个变量的值是一致的
2. volatile实现原理
那么Volatile是如何来保证可见性的呢?在x86处理器下通过工具获取JIT编译器生成的汇编指令来看看对Volatile进行写操作CPU会做什么事情。
Java代码: instance = new Singleton();//instance是volatile变量
汇编代码: 0x01a3de1d: movb $0x0,0x1104800(%esi);0x01a3de24: lock addl $0x0,(%esp);
有volatile变量修饰的共享变量进行写操作的时候会多第二行汇编代码,通过查IA-32架构软件开发者手册可知,lock前缀的指令在多核处理器下会引发了两件事情。
将当前处理器缓存行的数据会写回到系统内存。
这个写回内存的操作会引起在其他CPU里缓存了该内存地址的数据无效。
处理器为了提高处理速度,不直接和内存进行通讯,而是先将系统内存的数据读到内部缓存(L1,L2或其他)后再进行操作,但操作完之后不知道何时会写到内存,如果对声明了Volatile变量进行写操作,JVM就会向处理器发送一条Lock前缀的指令,将这个变量所在缓存行的数据写回到系统内存。但是就算写回到内存,如果其他处理器缓存的值还是旧的,再执行计算操作就会有问题,所以在多处理器下,为了保证各个处理器的缓存是一致的,就会实现缓存一致性协议,每个处理器通过嗅探在总线上传播的数据来检查自己缓存的值是不是过期了,当处理器发现自己缓存行对应的内存地址被修改,就会将当前处理器的缓存行设置成无效状态,当处理器要对这个数据进行修改操作的时候,会强制重新从系统内存里把数据读到处理器缓存里。
Lock前缀指令会引起处理器缓存回写到内存。Lock前缀指令导致在执行指令期间,声言处理器的 LOCK# 信号。在多处理器环境中,LOCK# 信号确保在声言该信号期间,处理器可以独占使用任何共享内存。(因为它会锁住总线,导致其他CPU不能访问总线,不能访问总线就意味着不能访问系统内存),但是在最近的处理器里,LOCK#信号一般不锁总线,而是锁缓存,毕竟锁总线开销比较大。在8.1.4章节有详细说明锁定操作对处理器缓存的影响,对于Intel486和Pentium处理器,在锁操作时,总是在总线上声言LOCK#信号。但在P6和最近的处理器中,如果访问的内存区域已经缓存在处理器内部,则不会声言LOCK#信号。相反地,它会锁定这块内存区域的缓存并回写到内存,并使用缓存一致性机制来确保修改的原子性,此操作被称为“缓存锁定”,缓存一致性机制会阻止同时修改被两个以上处理器缓存的内存区域数据。
一个处理器的缓存回写到内存会导致其他处理器的缓存无效。IA-32处理器和Intel 64处理器使用MESI(修改,独占,共享,无效)控制协议去维护内部缓存和其他处理器缓存的一致性。在多核处理器系统中进行操作的时候,IA-32 和Intel 64处理器能嗅探其他处理器访问系统内存和它们的内部缓存。它们使用嗅探技术保证它的内部缓存,系统内存和其他处理器的缓存的数据在总线上保持一致。例如在Pentium和P6 family处理器中,如果通过嗅探一个处理器来检测其他处理器打算写内存地址,而这个地址当前处理共享状态,那么正在嗅探的处理器将无效它的缓存行,在下次访问相同内存地址时,强制执行缓存行填充
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# volatile的实现原理
# java volatile的实现原理
# java volatile
# 多核
# 写到
# 线上
# 多处
# 读到
# 见性
# 它在
# 量能
# 它会
# 情况下
# 器中
# 就会
# 是在
# 但在
# 希望能
# 详细说明
# 来看看
# 或其他
# 被称为
# 发现自己
相关文章:
网站制作知乎推荐,想做自己的网站用什么工具比较好?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
如何在服务器上三步完成建站并提升流量?
网站建设制作需要多少钱费用,自己做一个网站要多少钱,模板一般多少钱?
昆明网站制作哪家好,昆明公租房申请网上登录入口?
公司网站建设制作费用,想建设一个属于自己的企业网站,该如何去做?
如何配置IIS站点权限与局域网访问?
如何零基础开发自助建站系统?完整教程解析
定制建站是什么?如何实现个性化需求?
独立制作一个网站多少钱,建立网站需要花多少钱?
广德云建站网站建设方案与建站流程优化指南
如何快速搭建安全的FTP站点?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?
建站主机与虚拟主机有何区别?如何选择最优方案?
如何用搬瓦工VPS快速搭建个人网站?
历史网站制作软件,华为如何找回被删除的网站?
宝塔建站助手安装配置与建站模板使用全流程解析
建站之星如何实现网站加密操作?
太原网站制作公司有哪些,网约车营运证查询官网?
免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?
武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?
南宁网站建设制作定制,南宁网站建设可以定制吗?
香港服务器网站卡顿?如何解决网络延迟与负载问题?
建站主机如何选?性能与价格怎样平衡?
建站之星如何通过成品分离优化网站效率?
金*站制作公司有哪些,金华教育集团官网?
建站之星如何一键生成手机站?
制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?
建站主机空间推荐 高性价比配置与快速部署方案解析
如何选择高效稳定的ISP建站解决方案?
如何通过wdcp面板快速创建网站?
建站与域名管理如何高效结合?
C#怎么使用委托和事件 C# delegate与event编程方法
建站之星体验版:智能建站系统+响应式设计,多端适配快速建站
如何确保西部建站助手FTP传输的安全性?
制作销售网站教学视频,销售网站有哪些?
如何快速搭建个人网站并优化SEO?
如何在IIS中新建站点并解决端口绑定冲突?
如何在腾讯云服务器快速搭建个人网站?
微网站制作教程,不会写代码,不会编程,怎么样建自己的网站?
如何通过虚拟主机快速完成网站搭建?
实例解析angularjs的filter过滤器
专业公司网站制作公司,用什么语言做企业网站比较好?
深圳网站制作案例,网页的相关名词有哪些?
如何快速打造个性化非模板自助建站?
Python多线程使用规范_线程安全解析【教程】
巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成
如何高效利用200m空间完成建站?
C#怎么创建控制台应用 C# Console App项目创建方法
*请认真填写需求信息,我们会在24小时内与您取得联系。