IVdsHwProvider::QuerySubSystems 方法 (vdshwprv.h)

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

返回提供程序管理的子系统的枚举。

语法

HRESULT QuerySubSystems(
  [out] IEnumVdsObject **ppEnum
);

参数

[out] ppEnum

可用于将子系统枚举为子系统对象的IEnumVdsObject 接口指针的地址。 有关详细信息,请参阅 使用枚举对象。 当不再需要接口和每个子系统对象时,调用方必须通过调用 IUnknown::Release 方法释放它们。

返回值

此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用 HRESULT_FROM_WIN32 宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。

返回代码/值 说明
S_OK
返回子系统标识符的枚举。 如果提供程序不管理任何子系统,则枚举为空。
VDS_E_PROVIDER_CACHE_CORRUPT
0x8004241FL
此返回值表示提供程序内部存在软件或通信问题,该提供程序缓存有关数组的信息。 使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。
VDS_E_OBJECT_STATUS_FAILED
0x80042431L
提供程序处于失败状态,无法执行请求的操作。
VDS_E_ANOTHER_CALL_IN_PROGRESS
0x80042404L
另一个操作正在进行中:在上一个操作完成之前,此操作无法继续。
VDS_E_INITIALIZE_NOT_CALLED
0x80042402L
尚未调用初始化方法。

注解

返回的对象枚举当前连接到网络的所有子系统。 使用 IVdsHwProvider::Reenumerate 方法发现新的子系统。 使用 IVdsHwProvider::Refresh 方法刷新现有子系统的内部缓存提供程序数据。

要求

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

另请参阅

IEnumVdsObject

IVdsHwProvider

IVdsHwProvider::Reenumerate

IVdsHwProvider::Refresh