IVdsIscsiTarget::CreatePortalGroup 方法 (vdshwprv.h)

[从 Windows 8 和 Windows Server 2012 开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]

创建门户组。 可以通过通过 ppAsync 参数调用 IVdsAsync::Wait 来检索新门户组对象的接口指针。 返回 的 VDS_ASYNC_OUTPUT 结构包含 cpg.pPortalGroupUnk 成员中的卷对象接口指针。

语法

HRESULT CreatePortalGroup(
  [out] IVdsAsync **ppAsync
);

参数

[out] ppAsync

VDS 在返回时初始化的 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_S_ALREADY_EXISTS
0x00042714L
无法再创建门户组。 CreatePortalGroup 方法未创建新的门户组。 如果在 ppAsync 参数中返回的接口指针上调用 IVdsAsync::Wait 方法,则会检索现有的门户组对象。
VDS_E_PROVIDER_CACHE_CORRUPT
0x8004241FL
提供程序的缓存已损坏。 这表示提供程序内部存在软件或通信问题,该提供程序缓存有关附加设备的信息。 调用方可以使用 IVdsHwProvider::Reenumerate 方法,然后使用 IVdsHwProvider::Refresh 方法还原缓存。
VDS_E_OBJECT_DELETED
0x8004240BL
目标对象不再存在。
VDS_E_ANOTHER_CALL_IN_PROGRESS
0x80042404L
另一项操作正在进行中;在前面的操作完成之前,此操作无法继续。

要求

要求
最低受支持的客户端 Windows Vista [仅限桌面应用]
最低受支持的服务器 Windows Server 2003 R2 [仅限桌面应用]
目标平台 Windows
标头 vdshwprv.h
Library Uuid.lib
可再发行组件 VDS 1.1

另请参阅

IVdsAsync

IVdsIscsiTarget