IDebugControl4::GetContextStackTrace 方法 (dbgeng.h)
GetContextStackTrace 方法返回调用堆栈顶部的帧,从任意寄存器上下文开始,并为每个堆栈帧返回重建的寄存器上下文。
语法
HRESULT GetContextStackTrace(
[in, optional] PVOID StartContext,
[in] ULONG StartContextSize,
[out, optional] PDEBUG_STACK_FRAME Frames,
[in] ULONG FramesSize,
[out, optional] PVOID FrameContexts,
[in] ULONG FrameContextsSize,
[in] ULONG FrameContextsEntrySize,
[out, optional] PULONG FramesFilled
);
参数
[in, optional] StartContext
指定堆栈顶部的寄存器上下文。
[in] StartContextSize
指定 StartContext 寄存器上下文的大小(以字节为单位)。
[out, optional] Frames
接收堆栈帧。 此数组包含的元素数为 FrameSize。 如果 Frames 为 NULL,则不会返回此信息。
[in] FramesSize
指定数组 帧中的项数。
[out, optional] FrameContexts
接收堆栈中每个帧的重新构建的寄存器上下文。 此数组中的条目对应于 Frames 数组中的条目。 线程上下文的类型是目标有效处理器的 CONTEXT 结构。 如果 FrameContexts 为 NULL,则不会返回此信息。
[in] FrameContextsSize
指定 FrameContexts 指向的内存的大小(以字节为单位)。 返回的堆栈帧数等于返回的上下文数, FrameContextsSize 必须等于 FramesSize 乘以 FrameContextsEntrySize。
[in] FrameContextsEntrySize
指定 FrameContexts 中每个帧上下文的大小(以字节为单位)。
[out, optional] FramesFilled
接收 放置在数组帧 和 FrameContexts 上下文中的帧数。 如果 FramesFilled 为 NULL,则不会返回此信息。
返回值
返回代码 | 说明 |
---|---|
|
方法成功。 |
此方法还可以返回错误值。 有关详细信息,请参阅 返回值。
注解
可以使用 OutputContextStackTrace 打印返回到 Frame 和 FrameContext 的堆栈跟踪。
堆栈展开通常只还原寄存器的子集。 例如,堆栈展开并不总是还原可变寄存器状态,因为可变寄存器是暂存寄存器,代码不需要保留它们。 未在展开时还原的寄存器保留为还原的最后一个值,因此在使用可能无法通过展开还原的寄存器状态时应小心。
要求
要求 | 值 |
---|---|
目标平台 | 桌面 |
标头 | dbgeng.h (包括 Dbgeng.h、Ntddk.h) |