OpCodes.Ldelema 字段
定义
重要
一些信息与预发行产品相关,相应产品在发行之前可能会进行重大修改。 对于此处提供的信息,Microsoft 不作任何明示或暗示的担保。
将位于指定数组索引的数组元素的地址作为 &
类型(托管指针)加载到计算堆栈的顶部。
public: static initonly System::Reflection::Emit::OpCode Ldelema;
public static readonly System.Reflection.Emit.OpCode Ldelema;
staticval mutable Ldelema : System.Reflection.Emit.OpCode
Public Shared ReadOnly Ldelema As OpCode
字段值
注解
下表列出了指令的十六进制和 Microsoft 中间语言 (MSIL) 程序集格式,以及简短的参考摘要:
格式 | 程序集格式 | 说明 |
---|---|---|
8F <T > |
ldelema class |
将数组元素 index 的地址作为类型 & 加载到计算堆栈顶部, (托管指针) 。 |
堆栈过渡行为(按顺序排列)是:
对象引用
array
被推送到堆栈上。将索引值
index
推送到堆栈上。index
和array
从堆栈中弹出;将查找存储在 中array
的位置index
的地址。地址将推送到堆栈上。
ldelema
用于检索对象数组中特定索引处的对象的地址,该数组 (类型class
为) 。 指令 ldelema
将值的地址加载到索引 index
处, (类型 native int
) 从零开始的一维数组 array
中,并将其放置在堆栈的顶部。 数组是 对象,因此由 类型的 O
值表示。 值的类型必须与 class
指令一起传递。
的 ldelema
返回值是 (类型 &
) 的托管指针。
请注意,小于 4 个字节的整数值将 int32
扩展到 (加载到计算堆栈上时不 native int
) 。
NullReferenceException 如果 array
是空引用,则引发 。
ArrayTypeMismatchException 如果未 array
保存所需类型的元素,则引发 。
IndexOutOfRangeException 如果 index
为负或大于 的 array
边界,则引发 。
以下 Emit 方法重载可以使用 ldelema
操作码: