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 Esadecimale e MSIL (Microsoft Intermediate Language), insieme a un breve riepilogo dei riferimenti:

Formato Formato assembly Descrizione
C6 <T> mkrefany class Inserisce un riferimento tipizzato di tipo class nello stack.

Il comportamento di transizione dello stack, in ordine sequenziale, è:

  1. Viene eseguito il push di un puntatore a una 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 per 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 le istruzioni MSIL (Microsoft 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