開啟並準備與 .exe/.dll 檔案相關聯的偵錯數據。
語法
HRESULT loadDataFromCodeViewInfo (
LPCOLESTR executable,
LPCOLESTR searchPath,
DWORD cbCvInfo,
BYTE* pbCvInfo,
IUnknown* pCallback
);
參數
可執行檔
[in] .exe 或 .dll 檔案的路徑。
searchPath
[in]搜尋偵錯數據的替代路徑。 多個路徑應該以分號分隔。 路徑可能包含尾端 \。
cbCvInfo
[in]參數的 pbCvInfo 位元組大小。
pbCvInfo
[in]替代的偵錯標頭程式代碼檢視資訊(以取代可執行檔IMAGE_DEBUG_DIRECTORY的正常讀取內容)。 僅支援 RSDS 或 NB10 標頭。
pCallback
[in]IUnknown支援偵錯回呼介面的物件介面,例如 IDiaLoadCallback、、IDiaLoadCallback2IDiaReadExeAtOffsetCallback、 和/或 'IDiaReadExeAtRVACallback 介面。
傳回值
如果成功,則會傳回 S_OK;否則,會傳回錯誤碼。 下表顯示此方法的一些可能錯誤碼。
| 價值觀 | 說明 |
|---|---|
E_PDB_NOT_FOUND |
無法開啟檔案,或檔案的格式無效。 |
E_PDB_FORMAT |
嘗試存取格式不受支持的檔案。 |
E_PDB_INVALID_SIG |
簽章不相符。 |
E_PDB_INVALID_AGE |
年齡不相符。 |
E_INVALIDARG |
無效的參數。 |
E_UNEXPECTED |
數據源已經備妥。 |
備註
程式代碼檢視資訊 IMAGE_DEBUG_TYPE_CODEVIEW ,格式為相關聯的偵錯數據位置命名,並提供要比對的正負號和年齡字段。
如果您要從符號伺服器載入偵錯數據, symsrv.dll 必須存在於安裝使用者應用程式或 msdia140.dll 的相同目錄中,或者它必須存在於系統目錄中。
這個方法會讀取提供的偵錯標頭,然後搜尋並準備偵錯數據。 搜尋進度可選擇性地透過回呼來報告及控制。 例如, IDiaLoadCallback::NotifyDebugDir 當 方法尋找並處理偵錯目錄時 IDiaDataSource::loadDataForExe ,會叫用 。
和 IDiaReadExeAtOffsetCallbackIDiaReadExeAtRVACallback 介面可讓用戶端應用程式在無法透過標準檔案 I/O 直接存取檔案時,提供從可執行檔讀取資料的替代方法。
若要在不驗證的情況下載入 .pdb 檔案,請使用 IDiaDataSource::loadDataFromPdb 方法。
若要根據特定準則驗證 .pdb 檔案,請使用 IDiaDataSource::loadAndValidateDataFromPdb 方法。
若要直接從記憶體載入 .pdb 檔案,請使用 IDiaDataSource::loadDataFromIStream 方法。
若要驗證 .pdb 檔案而不載入它,請使用 IDiaDataSourceEx::ValidatePdb' 方法。
範例
BYTE pbCodeViewInfo[] = {
...
};
HRESULT hr = pSource->loadDataFromCodeViewInfo( L"myprog.exe", L".\debug", sizeof(pbCodeViewInfo), pbCodeViewInfo, nullptr);
if (FAILED(hr))
{
// Report error
}