内存屏障(Memory barrier)

内存屏障(Memory barrier)

为什么会有内存屏障

  • 每个CPU都会有自己的缓存(有的甚至L1,L2,L3),缓存的目的就是为了提高性能,避免每次都要向内存取。但是这样的弊端也很明显:不能实时的和内存发生信息交换,分在不同CPU执行的不同线程对同一个变量的缓存值不同。

  • 用volatile关键字修饰变量可以解决上述问题,那么volatile是如何做到这一点的呢?那就是内存屏障,内存屏障是硬件层的概念,不同的硬件平台实现内存屏障的手段并不是一样,java通过屏蔽这些差异,统一由jvm来生成内存屏障的指令。


内存屏障是什么

  • 硬件层的内存屏障分为两种:Load BarrierStore Barrier即读屏障和写屏障。

  • 内存屏障有两个作用:

  1. 阻止屏障两侧的指令重排序;

  2. 强制把写缓冲区/高速缓存中的脏数据等写回主内存,让缓存中相应的数据失效。

  • 对于Load Barrier来说,在指令前插入Load Barrier,可以让高速缓存中的数据失效,强制从新从主内存加载数据;

  • 对于Store Barrier来说,在指令后插入Store Barrier,能让写入缓存中的最新数据更新写入主内存,让其他线程可见。


java内存屏障

  • java的内存屏障通常所谓的四种即LoadLoad,StoreStore,LoadStore,StoreLoad实际上也是上述两种的组合,完成一系列的屏障和数据同步功能。

  • LoadLoad屏障:对于这样的语句Load1; LoadLoad; Load2,在Load2及后续读取操作要读取的数据被访问前,保证Load1要读取的数据被读取完毕。

  • StoreStore屏障:对于这样的语句Store1; StoreStore; Store2,在Store2及后续写入操作执行前,保证Store1的写入操作对其它处理器可见。

  • LoadStore屏障:对于这样的语句Load1; LoadStore; Store2,在Store2及后续写入操作被刷出前,保证Load1要读取的数据被读取完毕。

  • StoreLoad屏障:对于这样的语句Store1; StoreLoad; Load2,在Load2及后续所有读取操作执行前,保证Store1的写入对所有处理器可见。它的开销是四种屏障中最大的。在大多数处理器的实现中,这个屏障是个万能屏障,兼具其它三种内存屏障的功能


volatile语义中的内存屏障

  • volatile的内存屏障策略非常严格保守,非常悲观且毫无安全感的心态:

在每个volatile写操作前插入StoreStore屏障,在写操作后插入StoreLoad屏障;在每个volatile读操作前插入LoadLoad屏障,在读操作后插入LoadStore屏障;

  • 由于内存屏障的作用,避免了volatile变量和其它指令重排序、线程之间实现了通信,使得volatile表现出了锁的特性。

final语义中的内存屏障

  • 对于final域,编译器和CPU会遵循两个排序规则:

  1. 新建对象过程中,构造体中对final域的初始化写入和这个对象赋值给其他引用变量,这两个操作不能重排序;(废话嘛)

  2. 初次读包含final域的对象引用和读取这个final域,这两个操作不能重排序;(晦涩,意思就是先赋值引用,再调用final值)

  • 总之上面规则的意思可以这样理解,必需保证一个对象的所有final域被写入完毕后才能引用和读取。这也是内存屏障的起的作用:

  • 写final域:在编译器写final域完毕,构造体结束之前,会插入一个StoreStore屏障,保证前面的对final写入对其他线程/CPU可见,并阻止重排序。

  • 读final域:在上述规则2中,两步操作不能重排序的机理就是在读final域前插入了LoadLoad屏障。

  • X86处理器中,由于CPU不会对写-写操作进行重排序,所以StoreStore屏障会被省略;而X86也不会对逻辑上有先后依赖关系的操作进行重排序,所以LoadLoad也会变省略。

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
通过将链接(即从电子邮件)重定向到隐身窗口,帮助您远离其他可信网站。 您是否曾经在没有考虑的情况下跟踪过电子邮件的链接,而只是将其带到一个充满广告和其他废话的站点,而您却不想在您信任的站点附近找到它? 如果这听起来让您感到困扰,那么此扩展程序就是您一直在寻找的东西。 Great Barrier可让您维护您定期信任和/或使用的网站白名单。 如果您点击了指向未列入白名单的站点的链接,Great Barrier会将其重定向到“隐身”窗口,从而将其与您可能已打开的任何敏感会话隔离。 ****新增功能:0.94 ---- *新增了将重定向的链接保存到浏览器历史记录的功能(默认情况下处于禁用状态)。 如果您想在浏览时使用历史记录自动完成功能,可以启用此功能,使扩展程序在将URL重定向到隐身窗口之前,将URL保存到浏览器的历史记录。 当然,一旦您进入隐身模式,Chrome就会放弃您可能进行的所有进一步导航。 要添加此功能,需要在扩展程序添加“历史记录”权限。 ****该扩展程序是开放源代码,可通过以下网址免费获得:浏览Chrome网上应用店的网站链接。 该扩展名不记录,存储或传输任何个人信息或浏览历史信息。 您的设置可能已与Google的服务器同步,但此扩展程序的作者无法访问。 Great Barrier由加拿大卡尔顿大学的Gregory Bint和Gehana Booth创建,是一项可用的安全项目的一部分(目前,您可能已经知道名称的来源)。 该项目的灵感来自于作者对“分离浏览”的兴趣,这种思维方式旨在防止广告和其他跟踪技术与敏感的个人信息进行交互。 精美的艺术品由雷切尔·罗伯森(Rachel Robertson)提供。 通常,单独的浏览是通过简单地使用多个浏览器来完成的。 一个用于敏感站点,另一个用于常规浏览。 但是,即使是有上进心的人,在匆忙或分散注意力时,也可以通过简单的方法来阻止这种分离,例如跟随电子邮件消息的链接。 此扩展旨在提供无缝,自动的Web浏览分离,同时减少或消除了用户不断思考每个链接的方向的需求。 如果您对此扩展程序有任何疑问或反馈,通常是单独浏览或希望对我们的研究有所帮助,请通过greatbarrier@scs.carleton.ca或greatbarrier[email protected]与我们联系。 支持语言:English

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值