共用方式為


FunctionLeave2 函式

通知分析工具,函式即將傳回給呼叫端,並提供堆疊框架和函式傳回值的相關資訊。

語法

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

參數

funcId [in] 所傳回函式的識別碼。

clientData [in] 重新對應的函式識別碼,這是先前透過 FunctionIDMapper 函式所指定的分析工具。

func [in] 指向堆疊框架相關資訊的 COR_PRF_FRAME_INFO 值。

分析工具應將此視為不透明的控制代碼,可傳遞回 ICorProfilerInfo2::GetFunctionInfo2 方法中的執行引擎。

retvalRange [in] COR_PRF_FUNCTION_ARGUMENT_RANGE 結構的指標,會指定函式傳回值的記憶體位置。

若要存取傳回值資訊,就必須設定 COR_PRF_ENABLE_FUNCTION_RETVAL 旗標。 分析工具可以使用 ICorProfilerInfo::SetEventMask 方法來設定事件旗標。

備註

funcretvalRange 參數的值在 FunctionLeave2 函式傳回之後無效,因為值可能會變更或遭到終結。

FunctionLeave2 函式是回呼;您必須實作它。 實作必須使用 __declspec (naked) 儲存體類別屬性。

執行引擎在呼叫此函式之前不會儲存任何暫存器。

  • 進入時,您必須儲存使用的所有暫存器,包括浮點單位 (FPU)。

  • 離開時,您必須將其呼叫端推送的所有參數移出以還原堆疊。

FunctionLeave2 的實作不該封鎖,因為它會延遲記憶體回收。 實作不該嘗試記憶體回收,因為堆疊可能不是處於記憶體回收友善狀態。 如果嘗試記憶體回收,執行階段將會封鎖直到 FunctionLeave2 傳回為止。

此外,FunctionLeave2 函式不得呼叫受控程式碼,或以任何方式造成受控記憶體配置。

規格需求

平台:請參閱系統需求

標頭:CorProf.idl

程式庫:CorGuids.lib

.NET Framework版本:自 2.0 起可用

另請參閱