IVdsOpenVDisk::Merge 方法 (vds.h)

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

在差異鏈結中,將子虛擬磁碟與其父系合併。

語法

HRESULT Merge(
  [in]  MERGE_VIRTUAL_DISK_FLAG Flags,
  [in]  ULONG                   MergeDepth,
  [out] IVdsAsync               **ppAsync
);

參數

[in] Flags

指定虛擬磁碟合併方式 的MERGE_VIRTUAL_DISK_FLAG 列舉值。 必須設定為 MERGE_VIRTUAL_DISK_FLAG_NONE。

[in] MergeDepth

差異鏈結中要合併在一起的父磁碟數目。 磁碟必須已開啟,且 ReadWriteDepth 至少等於此值。

[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
已成功完成命令。

備註

只有在虛擬磁碟中斷連結時,才能合併虛擬磁碟。

這個方法會將所有數據區塊從子磁碟移至父系。 不過,它不會在作業結束時刪除無效的子磁碟。

虛擬磁碟必須已開啟且具有讀取/寫入存取權。

規格需求

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

另請參閱

IVdsOpenVDisk