现代操作系统是多处理器,每个处理器都有自己的缓存,这些缓存不是实时与内存交换信息。因此,cpu的缓存数据可能与另一个cpu的缓存数据不一致。这样,在多线程开发中,可能会发生异常行为操作系统的底层为这些问题提供了一些内存屏障来解决这些问题。
1、LoadLoad屏障
对于这样的语言Load1, LoadLoad2,在Load2和后续读取操作中读取的数据被访问之前,保证Load1读取的数据被读取。
2、StoreStore屏障
关于这样的语言Store1,StoreStore,Store2,在Store2和之后的写作执行之前,保证Store1的写作操作可以看到其他处理器。
3、LoadStore屏障
对于这样的语言Load1,LoadStore,Store2,在Store2和后续写作操作执行之前,保证Load1读取的数据被读取。
4、StoreLoad屏障
对于这样的语言Store1,StoreLoad;Load2,在Load2和后续的所有阅读操作实施之前,保证Store1的输入可以看到所有处理器。其费用是四种屏障中(冲刷缓冲器,清空无效化队列)。在大多数处理器的实现中,该屏障是万能屏障,兼具其他三种内存屏障功能。
以上就是java内存屏障的4种类型,希望对大家有所帮助。更多Java学习指路:Java基础
本教程操作环境:windows7系统、java10版,DELL G3电脑。