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 起可用