FunctionLeave3WithInfo 函数

通知探查器正在从函数返回控件,并提供可传递给 ICorProfilerInfo3::GetFunctionLeave3Info 方法的句柄以检索堆栈帧和返回值。

语法

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

参数

functionIDOrClientID [in] 从中返回控件的函数的标识符。

eltInfo [in] 表示有关给定堆栈帧的信息的不透明的句柄。 此句柄仅在其传递到的回调过程中有效。

注解

FunctionLeave3WithInfo 回调方法会在调用函数时通知探查器,并允许探查器使用 ICorProfilerInfo3::GetFunctionLeave3Info 方法检查返回值。 要访问返回值信息,必须设置 COR_PRF_ENABLE_FUNCTION_RETVAL 标志。 探查器可以使用 ICorProfilerInfo::SetEventMask 方法 设置事件标志,然后使用 ICorProfilerInfo3::SetEnterLeaveFunctionHooks3WithInfo 方法 来注册此函数的实现。

FunctionLeave3WithInfo 函数是一个回调;必须实现它。 实现必须使用 __declspec(naked) storage-class 属性。

在调用此函数之前,执行引擎不会保存任何寄存器。

  • 进入时,你需要保存你使用的所有寄存器,包括浮点单元 (FPU) 中的那些寄存器。

  • 退出时,必须通过弹出由其调用方推送的所有参数来还原堆栈。

FunctionLeave3WithInfo 的实现不应被阻止,因为它将延迟垃圾回收。 实现不应尝试垃圾回收,因为堆栈可能不处于对垃圾回收有利的状态。 如果尝试了垃圾回收,运行时将被阻止,直到 FunctionLeave3WithInfo 返回。

FunctionLeave3WithInfo 函数不得以任何方式调入托管代码,也不得导致托管内存分配。

要求

平台:请参阅系统要求

标头:CorProf.idl

库:CorGuids.lib

.NET Framework 版本:自 4 起可用

另请参阅