OpCodes.Volatile 字段
本文内容
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
指定当前位于计算堆栈顶部的地址可以是易失的,并且读取该位置的结果不能被缓存,或者对该地址的多个存储区不能被取消。
public: static initonly System::Reflection::Emit::OpCode Volatile;
public static readonly System.Reflection.Emit.OpCode Volatile;
staticval mutable Volatile : System.Reflection.Emit.OpCode
Public Shared ReadOnly Volatile As OpCode
下表列出了指令的十六进制和 Microsoft 中间语言 (MSIL) 程序集格式,以及简短的参考摘要:
格式 | 程序集格式 | 说明 |
---|---|---|
FE 13 | 挥发 性。 | 指示后续指针引用是可变的。 |
堆栈过渡行为(按顺序排列)是:
- 将地址推送到堆栈上。
volatile
. 指定该地址是易失性地址 (也就是说,可以在外部引用当前执行线程) 并且无法缓存读取该位置的结果,或者无法禁止显示该位置的多个存储。 将访问 volatile
标记为仅影响单个访问;对同一位置的其他访问必须单独标记。 无需以原子方式执行对易失位置的访问。
Unaligned和 volatile
前缀可以按任一顺序组合。 它们必须紧接在 、、stind
、、stfld
ldobj
ldfld
、stobj
、 initblk
或 cpblk
指令之前ldind
。
volatile
和 指令仅允许LdsfldStsfld前缀。
以下 Emit 方法重载可以使用 volatile
操作码:
适用于
产品 | 版本 |
---|---|
.NET | Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10 |
.NET Framework | 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1 |
.NET Standard | 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1 |
UWP | 10.0 |