次の方法で共有


FindDebugInfoFileExW 関数 (dbghelp.h)

指定した デバッグ (.dbg) ファイルを検索します。

構文

HANDLE IMAGEAPI FindDebugInfoFileExW(
  [in]           PCWSTR                     FileName,
  [in]           PCWSTR                     SymbolPath,
  [out]          PWSTR                      DebugFilePath,
  [in, optional] PFIND_DEBUG_FILE_CALLBACKW Callback,
  [in, optional] PVOID                      CallerData
);

パラメーター

[in] FileName

検索する .dbg ファイルの名前。 部分パスを使用できます。

[in] SymbolPath

シンボル ファイルが配置されているパス。 複数のパスをセミコロンで区切って指定できます。 シンボル パスを取得するには、SymGetSearchPath 関数を使用します。

[out] DebugFilePath

.dbg ファイルの完全なパスを受け取るバッファーへのポインター。

[in, optional] Callback

正しいファイルが見つかったか、関数が検索を続行する必要があるかを検証するアプリケーション定義のコールバック関数。 詳細については、「FindDebugInfoFileProcを する」を参照してください。

このパラメーターは NULLできます。

[in, optional] CallerData

コールバック関数に渡す省略可能なユーザー定義データ。

戻り値

関数が成功した場合、戻り値は .dbg ファイルへの開いているハンドルです。

関数が失敗した場合、戻り値は NULL。 拡張エラー情報を取得するには、GetLastError呼び出します。

備考

FindDebugInfoFileEx 関数を使用して、.dbg ファイルを検索します。 この関数は、1 つの関数呼び出しを介して複数の異なるディレクトリで検索を実行できるように提供されます。 SymbolPath パラメーターには複数のパスを含めることができます。各パスはセミコロン (;)で区切られます。 複数のパスを指定すると、関数は指定された各ディレクトリでファイルを検索します。 ファイルが見されると、検索は停止します。 したがって、SymbolPath パスを正しい順序で指定してください。

指定したファイル名に .dbg 拡張子が含まれていない場合は、FindDebugInfoFileEx 次の順序でファイルを検索

  1. SymbolPath\Symbols\ext\filename.dbg
  2. SymbolPath\ext\filename.dbg
  3. SymbolPath\filename.dbg
  4. FileNamePath\filename.dbg
この関数など、すべての DbgHelp 関数はシングル スレッドです。 そのため、複数のスレッドからこの関数を呼び出すと、予期しない動作やメモリ破損が発生する可能性があります。 これを回避するには、複数のスレッドからのすべての同時呼び出しをこの関数に同期する必要があります。

この関数の Unicode バージョンを呼び出すには、DBGHELP_TRANSLATE_TCHARを定義します。

手記

dbghelp.h ヘッダーは、Unicode プリプロセッサ定数の定義に基づいて、この関数の ANSI または Unicode バージョンを自動的に選択するエイリアスとして FindDebugInfoFileEx を定義します。 エンコードに依存しないエイリアスをエンコードに依存しないコードと組み合わせて使用すると、コンパイルエラーやランタイム エラーが発生する不一致が発生する可能性があります。 詳細については、「関数プロトタイプの 規則」を参照してください。

必要条件

要件 価値
ターゲット プラットフォーム の ウィンドウズ
ヘッダー dbghelp.h
ライブラリ Dbghelp.lib
DLL Dbghelp.dll
再頒布可能パッケージの DbgHelp.dll 5.1 以降

関連項目

DbgHelp 関数 の

FindDebugInfoFileProc の

SymGetSearchPath