OpCodes.Tailcall Campo

Definición

Ejecuta una instrucción máquina de llamada a método postfija de tal modo que el marco de pila del método actual se quita antes de que se ejecute la verdadera instrucción máquina de llamada.

public static readonly System.Reflection.Emit.OpCode Tailcall;

Valor de campo

Comentarios

En la tabla siguiente se muestra el formato de ensamblado hexadecimal y lenguaje intermedio de Microsoft (MSIL), junto con un breve resumen de referencia:

Formato Formato de ensamblado Descripción
FE 14 Cola. La llamada posterior finaliza los métodos actuales

No hay ningún comportamiento de transición de pila definido para esta instrucción.

La tail instrucción de prefijo debe preceder inmediatamente a una Callinstrucción , Callio Callvirt . Indica que se debe quitar el marco de pila del método actual antes de ejecutar la instrucción de llamada. También implica que el valor devuelto desde la siguiente llamada también es el valor devuelto por el método actual y, por tanto, la llamada se puede convertir en un salto entre métodos.

La pila debe estar vacía, excepto para los argumentos transferidos por la siguiente llamada. La instrucción que sigue a la instrucción de llamada debe ser un ret. Por lo tanto, la única secuencia de código válida es tail. call (o calli ).callvirt Las instrucciones correctas del lenguaje intermedio de Microsoft (MSIL) no deben bifurcarse a la call instrucción, pero pueden bifurcarse a la posterior Ret.

No se puede descartar el marco actual cuando el control se transfiere desde código que no es de confianza al código de confianza, ya que esto ponería en peligro la seguridad de la identidad del código. Por lo tanto, las comprobaciones de seguridad de .NET Framework pueden hacer tail que se omita, dejando una instrucción estándar Call . De forma similar, para permitir que se produzca la salida de una región sincronizada después de que se devuelva la llamada, el tail prefijo se omite cuando se usa para salir de un método marcado como sincronizado.

La sobrecarga del método siguiente Emit puede usar el tail código de operación:

Se aplica a

Producto Versiones
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0