IVdsVdProvider::CreateVDisk 方法 (vds.h)

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

建立虛擬磁片。

語法

HRESULT CreateVDisk(
  [in]  PVIRTUAL_STORAGE_TYPE        VirtualDeviceType,
  [in]  LPWSTR                       pPath,
  [in]  LPWSTR                       pStringSecurityDescriptor,
  [in]  CREATE_VIRTUAL_DISK_FLAG     Flags,
  [in]  ULONG                        ProviderSpecificFlags,
  [in]  ULONG                        Reserved,
  [in]  PVDS_CREATE_VDISK_PARAMETERS pCreateDiskParameters,
  [out] IVdsAsync                    **ppAsync
);

參數

[in] VirtualDeviceType

VIRTUAL_STORAGE_TYPE結構的指標,指定要建立的虛擬磁片類型。

[in] pPath

Null終止的寬字元字串,其中包含要為虛擬磁片建立備份檔案的名稱和目錄路徑。

[in] pStringSecurityDescriptor

Null終止的寬字元字串,包含要套用至虛擬磁片的安全性描述元。 如果此參數為 Null,則會使用呼叫端存取權杖中的安全性描述項。

[in] Flags

CREATE_VIRTUAL_DISK_FLAG列舉值的位元遮罩,指定虛擬磁片的建立方式。

意義
CREATE_VIRTUAL_DISK_FLAG_NONE
0x00000000
未指定旗標。
CREATE_VIRTUAL_DISK_FLAG_FULL_PHYSICAL_ALLOCATION
0x00000001
預先配置虛擬磁片虛擬大小所需的所有實體空間。 此旗標僅適用于固定大小的虛擬磁片。

[in] ProviderSpecificFlags

所建立虛擬磁片類型專屬的旗標位元遮罩。 這些旗標是提供者專屬的。 對於 Microsoft 虛擬磁片提供者,此參數必須為零。

[in] Reserved

參數是保留的,而且必須是零。

[in] pCreateDiskParameters

包含虛擬磁片建立參數 之VDS_CREATE_VDISK_PARAMETERS 結構的指標。

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

備註

應用程式必須藉由呼叫 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

另請參閱

IVdsVdProvider