共用方式為


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

產生堆疊追蹤之電腦的架構類型。 此參數可以是下列其中一個值。

意義
IMAGE_FILE_MACHINE_I386
0x014c
Intel x86
IMAGE_FILE_MACHINE_IA64
0x0200
Intel Itanium
IMAGE_FILE_MACHINE_AMD64
0x8664
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結構的AddrPCAddrFrame 和 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 或更新版本

另請參閱

上下文

DbgHelp 函式

FunctionTableAccessProc64

GetModuleBaseProc64

ReadProcessMemoryProc64

STACKFRAME64

TranslateAddressProc64