StackWalk64 函式 (dbghelp.h)
取得堆疊追蹤。
語法
BOOL IMAGEAPI StackWalk64(
[in] DWORD MachineType,
[in] HANDLE hProcess,
[in] HANDLE hThread,
[in, out] LPSTACKFRAME64 StackFrame,
[in, out] PVOID ContextRecord,
[in, optional] PREAD_PROCESS_MEMORY_ROUTINE64 ReadMemoryRoutine,
[in, optional] PFUNCTION_TABLE_ACCESS_ROUTINE64 FunctionTableAccessRoutine,
[in, optional] PGET_MODULE_BASE_ROUTINE64 GetModuleBaseRoutine,
[in, optional] PTRANSLATE_ADDRESS_ROUTINE64 TranslateAddress
);
參數
[in] MachineType
產生堆疊追蹤之電腦的架構類型。 此參數可以是下列其中一個值。
值 | 意義 |
---|---|
|
Intel x86 |
|
Intel Itanium |
|
x64 (AMD64 或 EM64T) |
[in] hProcess
產生堆疊追蹤之進程的控制碼。 如果呼叫端為 ReadMemoryRoutine 參數提供有效的回呼指標,則此值不一定是有效的進程控制碼。 對於 StackWalk64 函式的所有呼叫,它可以是唯一且一致且一致的權杖。 如果符號處理常式與 StackWalk64搭配使用,請針對每個函式的呼叫使用相同的進程控制碼。
[in] hThread
產生堆疊追蹤之執行緒的控制碼。 如果呼叫端為 ReadMemoryRoutine 參數提供有效的回呼指標,則此值不一定是有效的執行緒控制碼。 對於 StackWalk64 函式的所有呼叫,它可以是唯一且一致且一致的權杖。
[in, out] StackFrame
STACKFRAME64結構的指標。 如果函式呼叫成功,這個結構就會接收下一個框架的資訊。
[in, out] ContextRecord
CONTEXT結構的指標。 只有在 MachineType 參數未 IMAGE_FILE_MACHINE_I386時,才需要此參數。 不過,建議此參數包含有效的內容記錄。 這可讓 StackWalk64 處理各種不同的情況。
此內容可以修改,因此請勿傳遞不應修改的內容記錄。
[in, optional] ReadMemoryRoutine
提供記憶體讀取服務的回呼常式。 當 StackWalk64 函式需要從進程的位址空間讀取記憶體時,會使用 ReadProcessMemoryProc64 回呼。
如果此參數為 Null,則函式會使用預設常式。 在此情況下, hProcess 參數必須是有效的進程控制碼。
如果此參數不是 Null,應用程式應該實作並註冊處理 CBA_READ_MEMORY的符號處理常式回呼函式。
[in, optional] FunctionTableAccessRoutine
回呼常式,提供進程執行時間函式資料表的存取權。 這是必要參數,因為 StackWalk64 函式無法存取進程的執行時間函式資料表。 如需詳細資訊,請參閱 FunctionTableAccessProc64。
符號處理常式提供載入和存取執行時間資料表的函式。 如果使用這些函式,則 SymFunctionTableAccess64 可以傳遞為有效的參數。
[in, optional] GetModuleBaseRoutine
回呼常式,提供任何指定虛擬位址的模組基底。 此為必要參數。 如需詳細資訊,請參閱 GetModuleBaseProc64。
符號處理常式提供載入和維護模組資訊的函式。 如果使用這些函式, 則 SymGetModuleBase64 可以傳遞為有效的參數。
[in, optional] TranslateAddress
回呼常式,提供 16 位位址的位址轉譯。 如需詳細資訊,請參閱 TranslateAddressProc64。
StackWalk64的大部分呼叫端都可以安全地傳遞此參數的Null。
傳回值
如果函式成功,則傳回值為 TRUE。
如果函式失敗,則傳回值為 FALSE。 請注意, StackWalk64 通常不會設定最後一個錯誤碼。
備註
StackWalk64函式提供可攜式方法來取得堆疊追蹤。 建議使用 StackWalk64 函式來撰寫您自己的函式,因為平臺上與堆疊逐步執行相關的所有複雜度。 此外,還有一些編譯器選項會根據模組的編譯方式,以不同的方式顯示堆疊。 藉由使用此函式,您的應用程式具有可攜式堆疊追蹤,可在編譯器和作業系統變更時繼續運作。
如果未初始化在 StackFrame參數中傳遞之STACKFRAME64結構的AddrPC、AddrFrame 和 AddrStack成員,則對這個函式的第一次呼叫將會失敗。
所有 DbgHelp 函式,例如此函式都是單一執行緒。 因此,從多個執行緒呼叫此函式可能會導致非預期的行為或記憶體損毀。 若要避免這種情況,您必須將所有並行呼叫從多個執行緒同步處理到此函式。
此函式會取代 StackWalk 函式。 如需詳細資訊,請參閱 更新的平臺支援。 StackWalk 的定義如下:DbgHelp.h。
#if !defined(_IMAGEHLP_SOURCE_) && defined(_IMAGEHLP64)
#define StackWalk StackWalk64
#else
BOOL
IMAGEAPI
StackWalk(
DWORD MachineType,
__in HANDLE hProcess,
__in HANDLE hThread,
__inout LPSTACKFRAME StackFrame,
__inout PVOID ContextRecord,
__in_opt PREAD_PROCESS_MEMORY_ROUTINE ReadMemoryRoutine,
__in_opt PFUNCTION_TABLE_ACCESS_ROUTINE FunctionTableAccessRoutine,
__in_opt PGET_MODULE_BASE_ROUTINE GetModuleBaseRoutine,
__in_opt PTRANSLATE_ADDRESS_ROUTINE TranslateAddress
);
#endif
需求
目標平台 | Windows |
標頭 | dbghelp.h |
程式庫 | DbgHelp.lib |
Dll | DbgHelp.dll |
可轉散發套件 | DbgHelp.dll 5.1 或更新版本 |