内存屏障和volatile内存语义的实现
Posted it馅儿包子
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了内存屏障和volatile内存语义的实现相关的知识,希望对你有一定的参考价值。
趁周末,把以前的书拿出来,再翻一番,顺便做个笔记:
内存屏障:用来控制和规范cpu对内存操作的顺序的cpu指令。
内存屏障列表:
1.loadload:确保“前者数据装载”先于“后者装载指令”;
2.storestore:确保“前者数据”先于“后者数据”刷入系统内存,且,“前者刷入系统内存的数据”对“后者是可见的”;
3.loadstore:确保“前者装载数据”先于“后者刷新数据到系统内存”;
4.storeload:确保“前者刷入系统内存”的数据对“后者加载数据”是可见;
volatile的内存语义的(JVM)实现策略:
1.在每个volatile写操作前,会插入一个storeload屏障;
2.在每个volatile写操作后,会插入一个storeload屏障;
3.在每个volatile读操作后,会插入一个loadstore屏障和loadload屏障。
其上为java并发编程方向的理论基础知识。
以上是关于内存屏障和volatile内存语义的实现的主要内容,如果未能解决你的问题,请参考以下文章