OpCodes.Ldind_I4 字段
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
以间接方式将类型的 int32 值加载 int32 到评估堆栈上。
public: static initonly System::Reflection::Emit::OpCode Ldind_I4;
public static readonly System.Reflection.Emit.OpCode Ldind_I4;
staticval mutable Ldind_I4 : System.Reflection.Emit.OpCode
Public Shared ReadOnly Ldind_I4 As OpCode
字段值
注解
下表列出了指令的十六进制和Microsoft中间语言(MSIL)程序集格式,以及简短的参考摘要:
| Format | 程序集格式 | Description |
|---|---|---|
| 4A | ldind.i4 | 将 int32 地址 addr 处的值作为值 int32加载到堆栈上。 |
堆栈过渡行为按顺序排列,为:
地址被推送到堆栈上。
地址从堆栈中弹出;提取位于地址处的值。
提取的值被推送到堆栈上。
指令ldind.i4间接将指定地址(类型int32native int或 *)中的值作为一种&加载int32到堆栈上。
ldind所有指令都是指定Ldobj相应内置值类的指令的快捷方式。
请注意,在将小于 4 个字节的整数值加载到计算堆栈上时,这些值将扩展到 int32 (不是 native int)。 当加载到 F 评估堆栈时,浮点值将转换为类型。
格式正确的Microsoft中间语言(MSIL)可确保以与指针类型一致的方式使用 ldind 指令。
最初推送到堆栈上的地址必须与计算机上的对象的自然大小对齐,或者 NullReferenceException 可能发生(请参阅 Unaligned 预防措施的前缀说明)。 返回地址(例如 Ldloca ,和 Ldarga)的所有 MSIL 指令的结果都安全对齐。 对于大于 1 字节的数据类型,字节顺序取决于目标 CPU。 依赖于字节排序的代码可能不会在所有平台上运行。
NullReferenceException 如果检测到无效地址,则可以引发。
以下 Emit 方法重载可以使用 ldind.i4 操作码: