IVdsOpenVDisk::Attach 方法 (vds.h)

[從 Windows 8 和 Windows Server 2012 開始,虛擬磁碟服務 COM 介面會由 Windows 記憶體管理 API 取代。

鏈接虛擬磁碟。

語法

HRESULT Attach(
  [in]  LPWSTR                   pStringSecurityDescriptor,
  [in]  ATTACH_VIRTUAL_DISK_FLAG Flags,
  [in]  ULONG                    ProviderSpecificFlags,
  [in]  ULONG                    TimeoutInMs,
  [out] IVdsAsync                **ppAsync
);

參數

[in] pStringSecurityDescriptor

字串,包含虛擬磁碟的安全性描述項。 如果未指定,使用中的安全描述項為:「D:P (A;;Ga;;;Windows 7 上的 WD) ,以及 “D:P (A;;Ga;;;WD) (A;;Ga;;;Windows 8.1 和更新版本上的 AC) 」。

[in] Flags

指定虛擬磁碟連接方式 的ATTACH_VIRTUAL_DISK_FLAG 列舉值的位掩碼。 可能的值如下。

意義
ATTACH_VIRTUAL_DISK_FLAG_NONE
0x00000000
未指定旗標。
ATTACH_VIRTUAL_DISK_FLAG_READ_ONLY
0x00000001
將虛擬磁碟連結為唯讀。
ATTACH_VIRTUAL_DISK_FLAG_NO_DRIVE_LETTER
0x00000002
在鏈接的虛擬磁碟上掛接所有磁碟區,而不指派驅動器號給它們。
ATTACH_VIRTUAL_DISK_FLAG_PERMANENT_LIFETIME
0x00000004
VDS 服務會自動設定此旗標,以便在 呼叫 IVdsOpenVDisk::D etach 方法以中斷連結之前,VHD 會維持附加狀態。
ATTACH_VIRTUAL_DISK_FLAG_NO_LOCAL_HOST
0x00000008
保留的。 請勿使用。

[in] ProviderSpecificFlags

旗標的位掩碼,其專屬於所連接的虛擬磁碟類型。 這些旗標是提供者專屬的。 對於 Microsoft 虛擬磁碟提供者,此參數必須為零。

[in] TimeoutInMs

這個參數保留給未來使用。

[out] ppAsync

在成功完成時 ,IVdsAsync 介面的指標會收到 IVdsAsync 介面來監視和控制這項作業。 呼叫端必須在介面完成時釋放收到的介面。 如果在介面上呼叫 IVdsAsync::Wait 方法,並傳回成功的 HRESULT 值,則必須在每個介面指標上呼叫 IUnknown::Release 方法,以釋放VDS_ASYNC_OUTPUT結構中傳回的介面。 不過,如果 Wait 傳回失敗 HRESULT 值,或 WaitpHrResult 參數收到失敗 HRESULT 值,則VDS_ASYNC_OUTPUT結構中的介面指標為 NULL 且不需要釋放。 您可以使用 Winerror.h 中定義的 SUCCEEDEDFAILED 宏來測試成功或失敗 HRESULT 值。

傳回值

這個方法可以傳回標準 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 VDS 特定的傳回值。 它也可以使用 HRESULT_FROM_WIN32 宏傳回已轉換的系統錯誤碼。 錯誤可能源自 VDS 本身,或來自正在使用的基礎 VDS 提供者 。 可能的傳回值包括下列專案。

傳回碼 描述
S_OK
已成功完成命令。

備註

鏈接虛擬磁碟時,呼叫端可以接收下列一或所有通知:

  • 如果呼叫端已註冊 VDS 通知,則呼叫端會收到磁碟抵達通知。 如需詳細資訊,請參閱 VDS 通知
  • 如果呼叫端已註冊 PnP 通知,則呼叫端會收到 PnP 磁碟抵達通知。 如需詳細資訊,請參閱 RegisterDeviceNotification
應用程式必須藉由呼叫 CoInitializeSecurity 函式來初始化整個進程的安全性。 dwImpLevel 參數應該設定為 RPC_C_IMP_LEVEL_IMPERSONATE

Windows Server 2008、Windows Vista 和 Windows Server 2003: 在 Windows 7 和 Windows Server 2008 R2 之前,不需要這些動作。

規格需求

需求
最低支援的用戶端 Windows 7 [僅限傳統型應用程式]
最低支援的伺服器 Windows Server 2008 R2 [僅限桌面應用程式]
目標平台 Windows
標頭 vds.h
程式庫 Uuid.lib

另請參閱

IVdsOpenVDisk