关于指令重排内存屏障和总线风暴

指令重排

java语言规范规定JVM线程内部维持顺序化语义。即只要程序的最终结果与它顺序化情况的结果相等,那么指令的执行顺序可以与代码顺序不一致,此过程叫指令的重排序。
从源码到最后执行的指令序列过程是:
源码->编译器优化重排序->指令级并行重排序->内存系统重排序->最后执行的指令序列

内存屏障

内存屏障可以禁止指令重排序
在这里插入图片描述
从上图可以看出:
1)当第二个操作是volatile写时,不管第一个操作是什么,都不能重排序。这个规则确保volatile写之前的操作不会被编译器重排序到volatile写之后。
2)当第一个操作是volatile读时,不管第二个操作是什么,都不能重排序。这个规则确保volatile读之后的操作不会被编译器重排序到volatile读之前。
3)当第一个操作是volatile写,第二个操作是volatile读时,不能重排序。
JMM内存屏障插入策略:
1)在每个volatile写操作的前面插入一个StoreStore屏障。
2)在每个volatile写操作的后面插入一个StoreLoad屏障。
3)在每个volatile读操作的后面插入一个LoadLoad屏障。
4)在每个volatile读操作的后面插入一个LoadStore屏障。

总线风暴

由于volatile的mesi缓存一致性协议需要不断的从主内存嗅探和cas不断循环无效交互导致总线带宽达到峰值
解决办法:部分volatile和cas使用synchronize

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值