Java内存模型

在这里插入图片描述

在这里插入图片描述

缓存一致性协议

MESI四种状态
M:修改
E:独占
S:共享
I:无效
在这里插入图片描述
假如现在有CPU1和CPU2,主内存有变量X= 1 。现在要做 x+1的操作。 如果在变量 x = 1
上加上volatile,则就会触发MESI 当CPU1从主内存中读取到X=1时,CPU1会把此变量标记成独享状态
并监听总线,是否有其它CPU去读取此变量 当CPU2从主内存中读取X=1变量时,CPU1会通过嗅探机制监听到。
此时CPU1的X变量会变成共享状态。继续进行计算,计算完变成X=2。
此时要回写到主内存之前。先锁住缓存行。并标记X变量为修改状态。并向总线发消息。 其它CPU2监听总线时,会监听到,并把X标记成无效状态。
CPU1把变量X=2回写到主内存后,会由修改状态变成独享状态。
此时,如果CPU2如果想修改X变量时,要重启从主内存中读取。然后开始新的轮回

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值