내보내기(0) 인쇄
모두 확장
정보
요청한 주제가 아래에 표시됩니다. 그러나 이 주제는 이 라이브러리에 포함되지 않습니다.

OpCodes.Ldind_I1 필드

2013-12-13

int8 형식의 값을 int32로 계산 스택에 간접적으로 로드합니다.

Namespace:  System.Reflection.Emit
어셈블리:  mscorlib(mscorlib.dll)

public static readonly OpCode Ldind_I1

다음 표에서는 명령의 16진수 및 MSIL(Microsoft Intermediate Language) 어셈블리 형식을 간단한 설명과 함께 보여 줍니다.

형식

어셈블리 형식

설명

46

ldind.i1

주소 addr에 있는 int8 값을 int32로 스택에 로드합니다.

다음과 같이 순차적으로 스택 전환 동작이 발생합니다.

  1. 주소가 스택으로 푸시됩니다.

  2. 주소가 스택에서 팝되며 주소에 있는 값은 페치됩니다.

  3. 페치된 값이 스택으로 푸시됩니다.

ldind.i1 명령이 지정된 주소(native int, & 또는 * 형식)에서 int8 값을 int32로 스택에 간접적으로 로드합니다.

모든 ldind 명령은 해당하는 기본 제공 값 클래스를 지정하는 Ldobj 명령의 축약 형태입니다.

4바이트보다 작은 정수 값은 계산 스택에 로드될 때 native int가 아닌 int32로 확장됩니다. 부동 소수점 값은 계산 스택에 로드될 때 F 형식으로 변환됩니다.

올바른 형식의 MSIL은 ldind 명령이 포인터 형식에 맞게 사용되도록 합니다.

처음에 스택에 푸시된 주소는 시스템에 있는 개체의 원래 크기에 맞춰져야 하며 그렇지 않을 경우 NullReferenceException이 발생할 수 있습니다. 이러한 문제를 방지하는 방법에 대해서는 Unaligned 접두사 명령을 참조하세요. 주소를 반환하는 모든 MSIL 명령(예: LdlocaLdarga)의 결과는 안전하게 맞춰집니다. 1바이트보다 큰 데이터 형식의 경우 바이트 순서는 대상 CPU에 따라 좌우됩니다. 바이트 순서에 의존하는 코드는 모든 플랫폼에서 실행되지 않을 수도 있습니다.

잘못된 주소가 감지되면 NullReferenceException이 발생합니다.

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

  • ILGenerator.Emit(OpCode)

Windows Phone OS

지원되는 버전: 8.0, 7.1

Windows Phone

Microsoft는 MSDN 웹 사이트에 대한 귀하의 의견을 이해하기 위해 온라인 설문 조사를 진행하고 있습니다. 참여하도록 선택하시면 MSDN 웹 사이트에서 나가실 때 온라인 설문 조사가 표시됩니다.

참여하시겠습니까?
표시:
© 2014 Microsoft