面试系列之volatile(JMM)

面试系列之volatile(JMM)

JMM模型:
在这里插入图片描述

java并发编程中:
可见性:当一个线程修改了共享变量的值,其他线程能够看到修改的值。
顺序性:即程序执行的顺序按照代码的先后顺序执行。
原子性:一个或者多个操作一起全部执行不能被中断或者全部不执行

1.可见性:

  • 从JMM模型我们可以看出每个CPU都有自己的本地缓存,所以当多个CPU在操作同一个共享变量时会把共享变量读到自己的本地缓存中进行操作,但是操作完成之后并不会立即将结果写到主内存,由此产生了可见性的问题。
  • 所以在这种架构出来的时候就出现对 缓存一致性 的要求具体实现方案有两种:总线锁定缓存锁定 由于总线锁定会阻塞其他cpu的请求,独占主内存,对性能的损耗非常大,所以一般不使用。 缓存锁定是指内存区域如果被缓存在cpu的 缓存行 中那么对于这个内存的修改需要写会主内存并通知其他cpu中有此内存数据的缓存行失效
  • 缓存锁定的实现是基于总线窥探机制一般分为写失效写更新 基于效率考虑一般用写失效的方式
  • MESI(缓存一致性协议) 协议针对内存会有四种状态: M:修改 E:独占 S:共享 I:失效
    当对于一块内存,如果启用MESI协议,那么当它加载到一个CPU的缓存行时,它的状态是独占,第二个CPU加载时变为共享,CPU1或者CPU2操作完内存数据以后变为M,写回主内存后会通知其他CPU的对应缓存行变为失效。
  • 为满足可见性的要求,在jdk上的实现采用的是 内存屏障 ,内存屏障对于不同的运行平台底层的实现是不同的 举例:x86架构下的liux系统
    在这里插入图片描述
    可以看出经过storeload ->fence ->lock 所以使用的是lock前缀指令
  • 内存屏障:能够保证修改写到主内存并通知其他cpu的缓存行失效

2.顺序性:顺序性是指代码的执行顺序和编码顺序一致。
在这里插入图片描述
内存屏障能保证内存屏障前后的代码执行不会重排序
3.原子性:不保证原子性

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值