OpCodes.Ldind_Ref 字段

定义

将对象引用作为 O(对象引用)类型间接加载到计算堆栈上。

public: static initonly System::Reflection::Emit::OpCode Ldind_Ref;
public static readonly System.Reflection.Emit.OpCode Ldind_Ref;
 staticval mutable Ldind_Ref : System.Reflection.Emit.OpCode
Public Shared ReadOnly Ldind_Ref As OpCode 

字段值

注解

下表列出了指令的十六进制和 Microsoft 中间语言 (MSIL) 程序集格式,以及简短的参考摘要:

格式 程序集格式 说明
50 ldind.ref 将地址 addr 处的对象引用作为类型加载到堆栈上 O

堆栈过渡行为(按顺序排列)是:

  1. 将地址推送到堆栈上。

  2. 地址从堆栈中弹出;提取位于地址处的对象引用。

  3. 提取的引用将推送到堆栈上。

指令 ldind.ref 间接将对象引用类型 native int为 、 &或 *的指定地址 (加载到堆栈上,) 类型 O为 。

ldind所有指令都是指定相应内置值类的指令的快捷方式Ldobj

请注意,小于 4 个字节的整数值将 int32 扩展到 (加载到计算堆栈上时不 native int) 。 浮点值在加载到计算堆栈时转换为 F 类型。

格式正确的 Microsoft 中间语言 (MSIL) 可确保 ldind 以与指针类型一致的方式使用指令。

最初推送到堆栈上的地址必须与计算机上的对象的自然大小对齐, NullReferenceException 否则可能会发生 (查看 Unaligned) 预防措施的前缀指令。 例如 LdlocaLdarga ,返回地址和) 的所有 MSIL 指令的结果 (安全对齐。 对于大于 1 字节的数据类型,字节顺序取决于目标 CPU。 依赖于字节排序的代码可能不会在所有平台上运行。

NullReferenceException 如果检测到无效地址,可能会引发 。

以下 Emit 方法重载可以使用 ldind.ref 操作码:

适用于