Mar*_* Ba 6 c# multithreading volatile interlocked
Read(Int64).NET系统类System.Threading.Volatile和的方法有什么区别System.Threading.Interlocked?
具体而言,关于(a)原子性和(b)内存排序,它们各自的保证/行为是什么。
请注意,这是关于Volatile阶级,不是的volatile(小写)的关键字。
MS docs状态:
易读方法
读取字段的值。在需要它的系统上,插入一个内存屏障,以防止处理器按以下方式重新排序内存操作:如果在代码中此方法之后出现读取或写入,则处理器无法在此方法之前移动它。
...
退货
Int64读取的值。不管处理器数量或处理器缓存状态如何,此值都是计算机中任何处理器最新写入的值。
与
Interlocked.Read(Int64)方法
返回作为原子操作加载的64位值。
似乎特别令人困惑的是,这些Volatile文档没有谈论原子性,并且这些Interlocked文档没有谈论排序/内存障碍。
旁注:作为参考:我更熟悉C ++原子API,其中原子操作也总是指定内存排序语义。
Pavel有用地提供的问题链接(和可传递链接)很好地解释了挥发性记忆屏障和原子无撕裂阅读的区别/正交性,但它们并没有解释这两个概念如何应用于这两个类别。
Volatile.Read保证原子性?Interlocked.Read(或者,真的,任何的Interlocked功能)做出的内存为了任何保证?Interlocked.Read translates into a CompareExchange operation:
public static long Read(ref long location)
{
return Interlocked.CompareExchange(ref location, 0, 0);
}
Run Code Online (Sandbox Code Playgroud)
Therefore it has all the benefits of CompareExchange:
Volatile.Read on the other hand has only acquire semantics. It helps you ensuring the execution order of your read operations, without any atomicity or freshness guarantee.
| 归档时间: |
|
| 查看次数: |
100 次 |
| 最近记录: |