OpCodes.Ldind_U2 Campo

Definizione

Carica indirettamente un valore di tipo unsigned int16 come oggetto int32 nello stack di valutazione.

public: static initonly System::Reflection::Emit::OpCode Ldind_U2;
public static readonly System.Reflection.Emit.OpCode Ldind_U2;
 staticval mutable Ldind_U2 : System.Reflection.Emit.OpCode
Public Shared ReadOnly Ldind_U2 As OpCode 

Valore del campo

Commenti

La tabella seguente elenca il formato di assembly MSIL (Intermediate Language) esadecimale e Microsoft istruzione, insieme a un breve riepilogo di riferimento:

Formato Formato assembly Descrzione
49 ldind.u2 Carica il unsigned int16 valore in corrispondenza dell'indirizzo addr nello stack come .int32

Il comportamento transitorio dello stack, in ordine sequenziale, è:

  1. Viene eseguito il push di un indirizzo nello stack.

  2. L'indirizzo viene estratto dallo stack; il valore che si trova nell'indirizzo viene recuperato.

  3. Il valore recuperato viene inserito nello stack.

L'istruzione ldind.u2 carica indirettamente un unsigned int16 valore dall'indirizzo specificato (di tipo native int, &o *) nello stack come int32.

Tutte le ldind istruzioni sono collegamenti per un'istruzione Ldobj che specifica la classe valore predefinita corrispondente.

Si noti che i valori integer minori di 4 byte vengono estesi a int32 (non native int) quando vengono caricati nello stack di valutazione. I valori a virgola mobile vengono convertiti in F tipo quando vengono caricati nello stack di valutazione.

Il formato corretto Microsoft MSIL (Intermediate Language) garantisce che le istruzioni ldind vengano usate in modo coerente con il tipo del puntatore.

L'indirizzo inizialmente inserito nello stack deve essere allineato alle dimensioni naturali degli oggetti nel computer oppure può verificarsi un'istruzione NullReferenceExceptionUnaligned di prefisso per le misure preventive. I risultati di tutte le istruzioni MSIL che restituiscono indirizzi (ad esempio, Ldloca e Ldarga) sono allineati in modo sicuro. Per i tipi di dati maggiori di 1 byte, l'ordinamento dei byte dipende dalla CPU di destinazione. Il codice che dipende dall'ordinamento dei byte potrebbe non essere eseguito in tutte le piattaforme.

NullReferenceException può essere generata se viene rilevato un indirizzo non valido.

L'overload del metodo seguente Emit può usare il ldind.u2 codice operativo:

Si applica a