共用方式為


GetFileVersionInfoExW 函式 (winver.h)

擷取指定檔案的版本資訊。

語法

BOOL GetFileVersionInfoExW(
  [in]  DWORD   dwFlags,
  [in]  LPCWSTR lpwstrFilename,
        DWORD   dwHandle,
  [in]  DWORD   dwLen,
  [out] LPVOID  lpData
);

參數

[in] dwFlags

類型:DWORD

控制從中擷取版本資源的 MUI DLL(如果有的話)。 這個旗標的值必須符合傳遞至對應 GetFileVersionInfoSizeEx 呼叫的旗標,此呼叫用來判斷傳入 dwLen 參數中的緩衝區大小。 下列旗標的零或多個。

價值 意義
FILE_VER_GET_LOCALISED
0x01
如果有的話,從對應的 MUI 檔案載入整個版本資源(字串和二進位版本資訊)。
FILE_VER_GET_NEUTRAL
0x02
如果有的話,請從對應的 MUI 檔案載入版本資源字串,並在可用時從對應的語言中性檔案載入二進位版本資訊 (VS_FIXEDFILEINFO)。
FILE_VER_GET_PREFETCHED
0x04
表示 version.dll 嘗試在載入器鎖定之外預先載入映像以避免爭用的喜好設定。 此旗標不會變更函式的行為或語意。

[in] lpwstrFilename

類型:LPCTSTR

檔名。 如果未指定完整路徑,則函式會使用由 LoadLibrary 函式指定的搜尋順序。

dwHandle

類型:DWORD

這個參數會被忽略。

[in] dwLen

類型:DWORD

lpData 參數所指向之緩衝區的大小,以位元組為單位。

先呼叫 GetFileVersionInfoSizeEx 函式,以位元組為單位來判斷檔案版本資訊的大小。 dwLen 參數應等於或大於該值。

如果 lpData 所指向的緩衝區不夠大,函式會將檔案的版本資訊截斷為緩衝區的大小。

[out] lpData

類型:LPVOID

當此函式傳回時,會包含包含檔案版本信息的緩衝區指標。

您可以在後續呼叫 VerQueryValue 函式中使用此值,從緩衝區擷取數據。

傳回值

類型:BOOL

如果函式成功,則傳回值為非零值。

如果函式失敗,傳回值為零。 若要取得擴充的錯誤資訊,請呼叫 GetLastError

言論

在呼叫 getFileVersionInfoEx 函式之前,先呼叫 GetFileVersionInfoSizeEx 函式。 若要從檔案版本信息緩衝區擷取資訊,請使用 VerQueryValue 函式。

注意

winver.h 標頭會根據 UNICODE 預處理器常數的定義,將 GetFileVersionInfoEx 定義為自動選取此函式的 ANSI 或 Unicode 版本。 混合使用編碼中性別名與非編碼中性的程序代碼,可能會導致編譯或運行時間錯誤不符。 如需詳細資訊,請參閱函式原型的 慣例。

要求

要求 價值
最低支援的用戶端 Windows Vista [僅限傳統型應用程式]
支援的最低伺服器 Windows Server 2008 [僅限傳統型應用程式]
目標平臺 窗戶
標頭 winver.h (包括 Windows.h)
連結庫 Version.lib
DLL Api-ms-win-core-version-l1-1-0.dll

另請參閱

概念

GetFileVersionInfo

GetFileVersionInfoSizeEx

參考

VS_VERSIONINFO

VerQueryValue

版本資訊