다음을 통해 공유


OpCodes.Ldelema 필드

정의

지정된 배열 인덱스에 있는 배열 요소의 주소를 & 형식(관리되는 포인터)으로 계산 스택 맨 위에 로드합니다.

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 

필드 값

설명

다음 표에는 간단한 참조 요약과 함께 명령의 16진수 및 MSIL(Microsoft Intermediate Language) 어셈블리 형식이 나와 있습니다.

서식 어셈블리 형식 Description
8f <T> ldelema class 의 배열 요소 index 주소를 평가 스택의 맨 위에 형식 & (관리형 포인터)으로 로드합니다.

스택 전환 동작은 순차적으로 다음과 같습니다.

  1. 개체 참조 array 가 스택에 푸시됩니다.

  2. 인덱스 값 index 이 스택에 푸시됩니다.

  3. indexarray 는 스택에서 팝됩니다. 의 위치에 indexarray 저장된 주소가 조회됩니다.

  4. 주소가 스택에 푸시됩니다.

ldelema 개체 배열(형식 class)의 특정 인덱스에서 개체의 주소를 검색하는 데 사용됩니다. 명령은 ldelema 0부터 시작하는 1차원 배열 array 의 인덱 index 스(형식native int)에 있는 값의 주소를 로드하고 스택 맨 위에 배치합니다. 배열은 개체이므로 형식 O의 값으로 표시됩니다. 값은 명령과 함께 전달된 형식 class 이어야 합니다.

ldelema 반환 값은 관리되는 포인터(형식 &)입니다.

4바이트 미만의 정수 값은 평가 스택에 로드될 때 (아님native int)로 확장 int32 됩니다.

NullReferenceException 가 null 참조이면 array throw됩니다.

ArrayTypeMismatchException array 가 필수 형식의 요소를 보유하지 않으면 throw됩니다.

IndexOutOfRangeException가 음수이거나 의 array경계보다 크면 index 이 throw됩니다.

다음 Emit 메서드 오버로드는 opcode를 ldelema 사용할 수 있습니다.

적용 대상