IVdsSubSystem2::GetDrive2 方法 (vdshwprv.h)

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

返回指定的驱动器。 此方法与 IVdsSubSystem::GetDrive 方法相同,只不过它包含机箱编号作为参数。

语法

HRESULT GetDrive2(
  [in]  SHORT     sBusNumber,
  [in]  SHORT     sSlotNumber,
  [in]  ULONG     ulEnclosureNumber,
  [out] IVdsDrive **ppDrive
);

参数

[in] sBusNumber

驱动器连接到的总线的编号。

[in] sSlotNumber

驱动器占用的槽数。

[in] ulEnclosureNumber

包含驱动器的机箱编号。 此参数对应于 VDS_DRIVE_PROP2 结构的 ulEnclosureNumber 成员。

[out] ppDrive

IVdsDrive 接口指针的地址。 调用方必须释放接口。

返回值

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

返回代码/值 说明
VDS_E_PROVIDER_CACHE_CORRUPT
0x8004241FL
缓存有关数组的信息的提供程序内部存在软件或通信问题。 使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。
VDS_E_OBJECT_DELETED
0x8004240BL
子系统对象不再存在。
VDS_E_OBJECT_STATUS_FAILED
0x80042431L
子系统处于失败状态,无法执行请求的操作。
VDS_E_ANOTHER_CALL_IN_PROGRESS
0x80042404L
另一项操作正在进行中;在上一个操作完成之前,此操作无法继续。

要求

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

另请参阅

IVdsDrive2

IVdsHwProvider::Reenumerate

IVdsHwProvider::Refresh

IVdsSubSystem2

IVdsSubSystem::GetDrive

IVdsSubSystem::QueryDrives