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
堆栈中弹出;将查找存储在位置index``array
的地址。地址被推送到堆栈上。
用于 ldelema
检索) 类型 class
(对象数组中特定索引处对象的地址。 该 ldelema
指令加载索引 index
(类型的 native int
值的地址) 从零开始的一维数组 array
中,并将其放在堆栈的顶部。 数组是对象,因此由类型的 O
值表示。 该值的类型必须使用 class
指令传递。
返回值为 ldelema
托管指针 (类型 &
) 。
请注意,当将小于 4 个字节的整数值加载到计算堆栈上时,这些整数值会 int32
扩展到 (不 native int
) 。
NullReferenceException is thrown if array
is a null reference.
ArrayTypeMismatchException 如果 array
不保存所需类型的元素,则会引发。
IndexOutOfRangeException 如果 index
为负值或大于其边界,则引发 array
。
以下 Emit 方法重载可以使用 ldelema
opcode: