共用方式為


SetupDiGetDeviceInstanceIdA 函式 (setupapi.h)

SetupDiGetDeviceInstanceId 函式會擷取與裝置資訊元素相關聯的 裝置實例 標識符。

注意

在 Windows Vista 和更新版本的 Windows 中,統一裝置屬性模型 會使用 DEVPKEY_Device_InstanceId屬性密鑰 來表示裝置實例識別符。 如需詳細資訊,請參閱 擷取裝置實例標識碼

語法

WINSETUPAPI BOOL SetupDiGetDeviceInstanceIdA(
  [in]            HDEVINFO         DeviceInfoSet,
  [in]            PSP_DEVINFO_DATA DeviceInfoData,
  [out, optional] PSTR             DeviceInstanceId,
  [in]            DWORD            DeviceInstanceIdSize,
  [out, optional] PDWORD           RequiredSize
);

參數

[in] DeviceInfoSet

裝置資訊集的句柄,其中包含代表要擷取裝置實例標識碼的裝置信息元素。

[in] DeviceInfoData

SP_DEVINFO_DATA 結構的指標,指定 deviceInfoSet中的裝置信息專案。

[out, optional] DeviceInstanceId

字元緩衝區的指標,將接收指定之裝置資訊元素的NULL終止裝置實例標識碼。 如需裝置實例識別碼的相關信息,請參閱 裝置識別字串

[in] DeviceInstanceIdSize

DeviceInstanceId 緩衝區的大小,以字元為單位。

[out, optional] RequiredSize

變數的指標,接收儲存裝置實例標識碼所需的字元數。

傳回值

如果函式成功,函式會傳回 TRUE。 否則,它會傳回 FALSE,而且可以藉由呼叫 getLastError 來擷取記錄的錯誤。

言論

注意

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

要求

要求 價值
最低支援的用戶端 Microsoft Windows 2000 和更新版本的 Windows 中提供。
目標平臺 桌面
標頭 setupapi.h (包括 Setupapi.h)
連結庫 Setupapi.lib

另請參閱

SP_DEVINFO_DATA

SetupDiCreateDevRegKey

SetupDiCreateDeviceInfo

SetupDiOpenDevRegKey

SetupDiOpenDeviceInfo