volatile、synchronized、CAS等原子性、可见性、有序性的保证

在这里插入图片描述

一、synchronized

1.synchronized的锁升级特性:对象头中的Mark Word字段在这里插入图片描述

2.多线程竞争Monitor时,过程如下:在这里插入图片描述

在这里插入图片描述

3.synchronized的锁优化:

在这里插入图片描述

二、volatile

1.volatile可见性的保证:

对于可见性,通过LOCK#前缀指令保证当前内存锁定主内存,进行安全修改;然后基于缓存一致性协议+其它线程的处理器嗅探技术,使得其它线程的缓存行失效,查询时从主内存查,保证数据一致性;

Java程序执行时会编译为字节码通过加载器加载到JVM中,JVM执行字节码最终将其转变为汇编代码相关的CPU指令;
对于使用【volatile关键字修饰的变量】,将其转变为汇编指令后比其他普通的变量多一行以【LOCK#为前缀的指令】;
LOCK#前缀指令相当于一个内存屏障,作用是:将主内存中的变量锁定,只能被一个线程所访问,类似于synchronized;
在这里插入图片描述
在这里插入图片描述

2.volatile有序性的保证:

对于有序性,volatile通过设置【读写内存屏障】来保证,硬件层的内存屏障主要分为两种Load Barrier,Store Barrier,即读屏障和写屏障。对于Java内存屏障来说,它分为四种,即这两种屏障的排列组合。

1、每次执行use操作的时候都先执行read和load操作,让volatile修饰的变量每次获取的都是新的值
2、每次执行assign的时候,随后都会执行store和write操作,让volatile修饰的变量每次都刷新到主内存中
在这里插入图片描述

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

征程123

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值