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.OpCodePublic 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 操作码: