System.Reflection.Emit.OpCodes.Ldelem_Ref Field

Loads the element containing an object reference at a specified array index onto the top of the evaluation stack as type O (object reference).

Syntax

public static readonly OpCode Ldelem_Ref

Remarks

The following table lists the instruction's hexadecimal and Microsoft Intermediate Language (MSIL) assembly format, along with a brief reference summary:

9A

ldelem.ref

Loads the element with an object reference at index onto the top of the stack as type O.

The stack transitional behavior, in sequential order, is:

[The 'ordered' type of list has not been implemented in the ECMA stylesheet.]

The ldelem.ref instruction loads the value of the element with index index (type native int) in the zero-based one-dimensional array array and places it on the top of the stack. Arrays are objects and hence represented by a value of type O.

The return value for ldelem.ref is type O (object reference).

NullReferenceException is thrown if array is a null reference.

ArrayTypeMismatchException is thrown if array does not hold elements of the required type.

IndexOutOfRangeException is thrown if index is negative, or larger than the bound of array.

The following ILGenerator.Emit(OpCode) method overload can use the ldelem.ref opcode:

  • ILGenerator.Emit(OpCode)

Requirements

Namespace: System.Reflection.Emit
Assembly: mscorlib (in mscorlib.dll)
Assembly Versions: 1.0.5000.0, 2.0.0.0, 4.0.0.0