IVdsLunPlex::QueryExtents 方法 (vdshwprv.h)

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

返回构成 plex 的驱动器盘区的数组。

语法

HRESULT QueryExtents(
  [out] VDS_DRIVE_EXTENT **ppExtentArray,
  [out] LONG             *plNumberOfExtents
);

参数

[out] ppExtentArray

指向调用方传入的驱动器盘区的指针数组的指针。 这些是导致 plex 的盘区。 请参阅 VDS_DRIVE_EXTENT 结构。 调用方必须使用 CoTaskMemFree 函数释放此数组。

[out] plNumberOfExtents

指向 ppExtentArray 中返回的驱动器盘区数的指针。

返回值

此方法可以返回标准 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
LUN plex 不再存在。
VDS_E_OBJECT_STATUS_FAILED
0x80042431L
LUN plex 处于失败状态,无法执行请求的操作。
VDS_E_ANOTHER_CALL_IN_PROGRESS
0x80042404L
另一项操作正在进行中;在上一个操作完成之前,此操作无法继续。

注解

使用 IVdsDrive::QueryExtents 方法获取给定驱动器上的盘区。

要求

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

另请参阅

IVdsDrive::QueryExtents

IVdsHwProvider::Reenumerate

IVdsHwProvider::Refresh

IVdsLunPlex

VDS_DRIVE_EXTENT