IVdsVolume::BreakPlex 方法 (vds.h)

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

從目前的磁碟區中移除指定的 plex。 透過 ppAsync 參數呼叫 IVdsAsync::Wait,即可擷取新磁碟區物件的介面指標。 傳回 的VDS_ASYNC_OUTPUT 結構包含 bvp.pVolumeUnk 成員中的磁碟區物件介面指標。

語法

HRESULT BreakPlex(
  [in]  VDS_OBJECT_ID plexId,
  [out] IVdsAsync     **ppAsync
);

參數

[in] plexId

要中斷之 plex 的 GUID。

[out] ppAsync

IVdsAsync 介面指標的位址,VDS 會在傳回時初始化。 呼叫端必須釋放 介面。 使用此指標來取消、等候或查詢作業的狀態。

如果您在此方法上呼叫 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
plex 已成功中斷。
VDS_E_VOLUME_NOT_ONLINE
0x8004243DL
磁碟區無法使用。
VDS_E_VOLUME_NOT_A_MIRROR
0x80042445L
磁碟區不是鏡像。

備註

這項作業對只有一個 plex 的基本磁碟區無效。

使用這個方法來中斷鏡像。 中斷的 plex 會變成新的磁碟區。 如果剩餘的 plex 已過時或遺失,VDS 會停止作業並傳回錯誤。 請注意,VDS 會在作業期間卸除磁碟區。

開機或系統 plex 基本上,用來開機計算機的 plex 對 plexId 無效。 當傳遞這類 plex 時,VDS 會停止作業並傳回錯誤。

不論呼叫是否起始異步操作,實作者都必須針對這個方法傳回 IVdsAsync 介面的指標。

規格需求

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

另請參閱

IVdsAsync

IVdsAsync::Wait

IVdsVolume

VDS_ASYNC_OUTPUT