Compartir a través de


FunctionLeave3WithInfo (Función)

Notifica al generador de perfiles que se devuelve el control desde una función y proporciona un identificador que se puede pasar al método ICorProfilerInfo3::GetFunctionLeave3Info para recuperar el marco de pila y el valor devuelto.

void __stdcall FunctionLeave3WithInfo(
               [in] FunctionIDOrClientID functionIDOrClientID,
               [in] COR_PRF_ELT_INFO eltInfo);

Parámetros

  • functionIDOrClientID
    [in] Identificador de la función de la que se devuelve el control.

  • eltInfo
    [in] Identificador opaco que representa información acerca de un marco de pila especificado. Este identificador solo es válido durante la devolución de llamada a la que se pasa.

Comentarios

El método de devolución de llamada FunctionLeave3WithInfo notifica al generador de perfiles cuando se llama a las funciones, y permite al generador de perfiles usar el método ICorProfilerInfo3::GetFunctionLeave3Info para inspeccionar el valor devuelto. Para tener acceso a la información del valor devuelto, se debe establecer la marca COR_PRF_ENABLE_FUNCTION_RETVAL. El generador de perfiles puede usar el método ICorProfilerInfo::SetEventMask para establecer las marcas de evento y, a continuación, usar el método ICorProfilerInfo3::SetEnterLeaveFunctionHooks3WithInfo para registrar su implementación de esta función.

La función FunctionLeave3WithInfo es una devolución de llamada; debe implementarla. La implementación debe utilizar el atributo de clase de almacenamiento __declspec(naked).

El motor de ejecución no guarda ningún registro antes de llamar a esta función.

  • En la entrada, debe guardar todos los registros que utilice, incluidos los de la unidad de punto flotante (FPU).

  • Al salir, debe restablecer la pila desactivando todos los parámetros insertados por el llamador.

La implementación de FunctionLeave3WithInfo no debe bloquearse porque retrasaría la recolección de elementos no utilizados. La implementación no debería intentar realizar la recolección de elementos no utilizados porque es posible que la pila no esté en un estado adecuado para ello. Si se intenta realizar una recolección de elementos no utilizados, el motor en tiempo de ejecución se bloqueará hasta que se devuelva FunctionLeave3WithInfo

La función FunctionLeave3WithInfo no debe llamar a código administrado ni provocar una asignación de memoria administrada de ninguna forma.

Requisitos

Plataformas: vea Requisitos de sistema de .NET Framework.

Encabezado: CorProf.idl

Biblioteca: CorGuids.lib

Versiones de .NET Framework: 4

Vea también

Referencia

GetFunctionLeave3Info

FunctionEnter3

FunctionLeave3

FunctionTailcall3

FunctionEnter3WithInfo

FunctionTailcall3WithInfo

SetEnterLeaveFunctionHooks3

SetEnterLeaveFunctionHooks3WithInfo

SetFunctionIDMapper

SetFunctionIDMapper2

Otros recursos

Funciones estáticas globales para generación de perfiles

Historial de cambios

Fecha

Historial

Motivo

Octubre de 2010

Se agregó __stdcall a la sintaxis.

Comentarios de los clientes.