Funzione FunctionLeave2FunctionLeave2 Function

Notifica al profiler che una funzione sta per restituire al chiamante e fornisce informazioni sul valore restituito dello stack frame e la funzione.Notifies the profiler that a function is about to return to the caller and provides information about the stack frame and function return value.

SintassiSyntax

void __stdcall FunctionLeave2 (  
    [in]  FunctionID                        funcId,  
    [in]  UINT_PTR                          clientData,  
    [in]  COR_PRF_FRAME_INFO                func,  
    [in]  COR_PRF_FUNCTION_ARGUMENT_RANGE  *retvalRange  
);  

ParametriParameters

funcId
[in] Identificatore della funzione che restituisce.[in] The identifier of the function that is returning.

clientData
[in] Identificatore della funzione modificato, quali il profiler specificato in precedenza tramite il FunctionIDMapper (funzione).[in] The remapped function identifier, which the profiler previously specified via the FunctionIDMapper function.

func
[in] Oggetto COR_PRF_FRAME_INFO che punta alle informazioni sullo stack frame.[in] A COR_PRF_FRAME_INFO value that points to information about the stack frame.

Il profiler deve trattare come handle opaco che può essere passato al motore di esecuzione di ICorProfilerInfo2:: Getfunctioninfo2 metodo.The profiler should treat this as an opaque handle that can be passed back to the execution engine in the ICorProfilerInfo2::GetFunctionInfo2 method.

retvalRange
[in] Un puntatore a un COR_PRF_FUNCTION_ARGUMENT_RANGE struttura che specifica la posizione di memoria del valore restituito della funzione.[in] A pointer to a COR_PRF_FUNCTION_ARGUMENT_RANGE structure that specifies the memory location of the function's return value.

Per accedere alle informazioni sul valore restituito, il COR_PRF_ENABLE_FUNCTION_RETVAL flag deve essere impostato.In order to access return value information, the COR_PRF_ENABLE_FUNCTION_RETVAL flag must be set. Il profiler può utilizzare il ICorProfilerInfo:: SetEventMask per impostare i flag dell'evento.The profiler can use the ICorProfilerInfo::SetEventMask method to set the event flags.

NoteRemarks

I valori del func e retvalRange parametri non sono validi dopo il FunctionLeave2 funzione perché i valori potrebbero cambiare o essere distrutti.The values of the func and retvalRange parameters are not valid after the FunctionLeave2 function returns because the values may change or be destroyed.

Il FunctionLeave2 funzione è un callback, è necessario implementarla.The FunctionLeave2 function is a callback; you must implement it. L'implementazione deve utilizzare il __declspec(naked) attributo della classe di archiviazione.The implementation must use the __declspec(naked) storage-class attribute.

Il motore di esecuzione non viene salvato alcun registro prima di chiamare questa funzione.The execution engine does not save any registers before calling this function.

  • In ingresso, è necessario salvare tutti i registri in uso, inclusi quelli in unità a virgola mobile (FPU).On entry, you must save all registers that you use, including those in the floating-point unit (FPU).

  • All'uscita, è necessario ripristinare lo stack recuperando tutti i parametri che sono stati inviati dal chiamante.On exit, you must restore the stack by popping off all the parameters that were pushed by its caller.

L'implementazione di FunctionLeave2 non devono bloccarsi perché ritarderà l'operazione di garbage collection.The implementation of FunctionLeave2 should not block because it will delay garbage collection. L'implementazione non deve tentare una garbage collection perché lo stack potrebbe non essere in uno stato di raccolta semplice garbage.The implementation should not attempt a garbage collection because the stack may not be in a garbage collection-friendly state. Se si tenta un'operazione di garbage collection, il runtime si bloccherà finché FunctionLeave2 restituisce.If a garbage collection is attempted, the runtime will block until FunctionLeave2 returns.

Inoltre, il FunctionLeave2 funzione non deve chiamare codice gestito o causare in alcun modo un'allocazione di memoria gestita.Also, the FunctionLeave2 function must not call into managed code or in any way cause a managed memory allocation.

RequisitiRequirements

Piattaforme: vedere requisiti di sistema.Platforms: See System Requirements.

Intestazione: Corprof. idlHeader: CorProf.idl

Libreria: CorGuids. libLibrary: CorGuids.lib

Versioni di .NET framework: Disponibile dalla 2.0Available since 2.0.NET Framework Versions: Disponibile dalla 2.0Available since 2.0

Vedere ancheSee Also

Funzione FunctionEnter2FunctionEnter2 Function
Funzione FunctionTailcall2FunctionTailcall2 Function
Metodo SetEnterLeaveFunctionHooks2SetEnterLeaveFunctionHooks2 Method
Funzioni statiche globali di profilaturaProfiling Global Static Functions