VB.NET:如果我总是用Thread.MemoryBarrier()完成我的写操作,我是否需要在每次读取之前调用Thread.MemoryBarrier()?

VB.Net没有等效的C#volatile关键字,因此您必须手动实现volatile,这通常通过在读取之前和写入之后调用Thread.MemoryBarrier()来完成.所以这样的东西等同于声明C#volatile变量:

''' <summary>
    ''' Gets a value indicating whether this instance is disposed.
    ''' </summary>
    Public Property IsDisposed As Boolean
        Get
            Threading.Thread.MemoryBarrier()
            Return _isDisposed
        End Get
        Private Set(value As Boolean)
            _isDisposed = value
            Threading.Thread.MemoryBarrier()
        End Set
    End Property

如果我写入变量的唯一地方是通过setter并且在写入之后我总是调用Thread.MemoryBarrier(),那么在读取之前我想知道内存屏障.

我可以在读取之前安全地删除Thread.MemoryBarrier()吗?

编辑:为了使它更清楚,我问我是否可以在读取之前删除Thread.MemoryBarrier(),以便为每次读取删除内存栅栏的成本.

解决方法

您无法移除读取侧的屏障,这可以通过示例轻松显示.让我们用这个读者:

while (!IsDisposed); //reads _isDisposed

_isDisposed的值可以清楚地缓存在这里的寄存器中,以便新的写入永远不会变得可见.这个循环可以是无限的(例如 – 其他影响是可能的,例如长延迟).

更正式地说,_isDisposed的读取都可以及时“向上”移动,以便在商店发生之前运行. volatile商店会影响释放栅栏,这意味着以后什么都不能移动它们.但是,事情可以转移到以前的时间点.

使用Volatile类.或者,使用C#编写的结构作为字段的包装:

struct VolatileInt32Box { public volatile int Value; }

相关文章

Format[$] ( expr [ , fmt ] ) format 返回变体型 format$ 强...
VB6或者ASP 格式化时间为 MM/dd/yyyy 格式,竟然没有好的办...
在项目中添加如下代码:新建窗口来显示异常信息。 Namespace...
转了这一篇文章,原来一直想用C#做k3的插件开发,vb没有C#用...
Sub 分列() ‘以空格为分隔符,连续空格只算1个。对所选...
  窗体代码 1 Private Sub Text1_OLEDragDrop(Data As Dat...