OpCodes.Mkrefany Campo

Definizione

Inserisce un riferimento tipizzato a un'istanza di un tipo specifico nello stack di valutazione.

public: static initonly System::Reflection::Emit::OpCode Mkrefany;
public static readonly System.Reflection.Emit.OpCode Mkrefany;
 staticval mutable Mkrefany : System.Reflection.Emit.OpCode
Public Shared ReadOnly Mkrefany 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 Description
C6 <T> mkrefany class Inserisce nello stack un riferimento tipizzato di tipo class .

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

  1. Viene eseguito il push di un puntatore a parte di dati nello stack.

  2. Il puntatore viene estratto e convertito in un riferimento tipizzato di tipo class.

  3. Il riferimento tipizzato viene inserito nello stack.

L'istruzione mkrefany supporta il passaggio di riferimenti tipizzato in modo dinamico. Il puntatore deve essere di tipo &, *o native inte contenere l'indirizzo valido di una parte di dati. Class è il token di classe che descrive il tipo di dati a cui fa riferimento il puntatore. Mkrefany esegue il push di un riferimento tipizzato nello stack, fornendo un descrittore opaco del puntatore e del tipo class.

L'unica operazione valida consentita su un riferimento tipizzato consiste nel passarlo a un metodo che richiede un riferimento tipizzato come parametro. Il chiamato può quindi usare le Refanytype istruzioni e Refanyval per recuperare rispettivamente il tipo (classe) e l'indirizzo.

TypeLoadException viene generata se class non è possibile trovare. Questo viene in genere rilevato quando Microsoft istruzioni MSIL (Intermediate Language) vengono convertite in codice nativo anziché in fase di esecuzione.

L'overload del metodo seguente Emit può usare il mkrefany codice operativo:

Si applica a