OpCodes.Ldelema 字段

定义

将位于指定数组索引的数组元素的地址作为 & 类型(托管指针)加载到计算堆栈的顶部。

public static readonly System.Reflection.Emit.OpCode Ldelema;

字段值

注解

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

格式 程序集格式 说明
8F <T> ldelema class 将数组元素 index 的地址作为类型 & 加载到计算堆栈顶部, (托管指针) 。

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

  1. 对象引用 array 被推送到堆栈上。

  2. 将索引值 index 推送到堆栈上。

  3. indexarray 从堆栈中弹出;将查找存储在 中array的位置index的地址。

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

ldelema用于检索对象数组中特定索引处的对象的地址,该数组 (类型class为) 。 指令 ldelema 将值的地址加载到索引 index 处, (类型 native int) 从零开始的一维数组 array 中,并将其放置在堆栈的顶部。 数组是 对象,因此由 类型的 O值表示。 值的类型必须与 class 指令一起传递。

ldelema 返回值是 (类型 &) 的托管指针。

请注意,小于 4 个字节的整数值将 int32 扩展到 (加载到计算堆栈上时不 native int) 。

NullReferenceException 如果 array 是空引用,则引发 。

ArrayTypeMismatchException 如果未 array 保存所需类型的元素,则引发 。

IndexOutOfRangeException 如果 index 为负或大于 的 array边界,则引发 。

以下 Emit 方法重载可以使用 ldelema 操作码:

适用于

产品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0