【说站】java内存屏障有哪些类型
java内存屏障有哪些类型
现代操作系统是多处理器,每个处理器都有自己的缓存,这些缓存不是实时与内存交换信息。因此,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电脑。
本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!
从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!
本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。
本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。
若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。