IDebugRegisters2::GetValues2 方法 (dbgeng.h)
GetValues2 方法會擷取目標之數個 快取器的值,。
語法
HRESULT GetValues2(
[in] ULONG Source,
[in] ULONG Count,
[in, optional] PULONG Indices,
[in] ULONG Start,
[out] PDEBUG_VALUE Values
);
參數
[in] Source
指定要查詢的緩存器來源。
下表列出可能的值。
價值 | 註冊來源 |
---|---|
DEBUG_REGSRC_DEBUGGEE | 從目標擷取註冊資訊。 |
DEBUG_REGSRC_EXPLICIT | 從目前的明確 快取器內容擷取快取器資訊,。 |
DEBUG_REGSRC_FRAME |
從目前範圍的緩存器內容擷取緩存器資訊。
注意 Stack 回溯並不保證緩存器內容的正確更新,因此範圍框架的緩存器內容在所有情況下可能都不正確。
|
[in] Count
指定要求其值的緩存器數目。
[in, optional] Indices
指定陣列,其中包含要從中取得值的緩存器索引。 此陣列中的元素數目 Count。 如果 索引NULL,則會改用 Start。
[in] Start
如果 索引NULL,則會從此索引開始連續讀取緩存器。 否則會忽略它。
[out] Values
接收快取器的值。 這個陣列保留的項目數目是 Count。 如需此參數類型的描述,請參閱 DEBUG_VALUE。
傳回值
此清單不包含可能發生的所有錯誤。 如需可能的錯誤清單,請參閱 HRESULT 值。
傳回碼 | 描述 |
---|---|
|
方法成功。 |
|
其中一個緩存器之索引的值大於目標電腦上的緩存器數目。 可能已取得部分結果;無法讀取的緩存器會有類型DEBUG_VALUE_INVALID。 |
言論
如果傳回值未S_OK,部分緩存器仍可能已讀取。 如果無法存取目標,則會E_UNEXPECTED傳回型別,且 值 不變。 否則,值 將包含部分結果,而且無法讀取的緩存器會有類型DEBUG_VALUE_INVALID。 在傳回值E_UNEXPECTED的情況下,可以避免模棱兩可,方法是先將 Values 的記憶體設定為零,再呼叫此方法。
GetValues 方法會執行與此方法相同的工作,但一律會使用目標做為緩存器來源。
如需 IDebugRegisters 介面和其他註冊相關方法的概觀,請參閱 Registers。
要求
要求 | 價值 |
---|---|
目標平臺 | 桌面 |
標頭 | dbgeng.h (include DbgEng.h) |