IVdsDrive::QueryExtents 方法 (vds.h)
[从Windows 8和Windows Server 2012开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]
返回驱动器上的盘区数组,包括已分配和未分配的盘区。
语法
HRESULT QueryExtents(
[out] VDS_DRIVE_EXTENT **ppExtentArray,
[out] LONG *plNumberOfExtents
);
参数
[out] ppExtentArray
指向调用方传入的 VDS_DRIVE_EXTENT 结构的数组的指针。 调用方必须使用 CoTaskMemFree 函数释放此数组。
[out] plNumberOfExtents
指向 VDS_DRIVE_EXTENT 结构中返回的驱动器盘区数的指针。
返回值
此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用 HRESULT_FROM_WIN32 宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。
返回代码/值 | 说明 |
---|---|
|
已成功返回盘区信息。 对于没有盘区的驱动器,数组为空, plNumberOfExtents 的值设置为 0,ppExtentArray 的值设置为 NULL。 |
|
此返回值表示提供程序内部存在软件或通信问题,该提供程序缓存有关数组的信息。 使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。 |
|
驱动器对象不再存在。 |
|
驱动器处于故障状态,无法执行请求的操作。 |
|
另一个操作正在进行中:在上一个操作完成之前,此操作无法继续。 |
|
子系统不支持此方法。 |
注解
驱动器可以向任意数量的 LUN 提供盘区,并且这些 LUN 可以取消屏蔽到网络上任意数量的不同计算机。 使用 IVdsLunPlex::QueryExtents 方法查看 LUN plex 的所有范围。
每个VDS_DRIVE_EXTENT结构的 LunId 成员指定每个分配的盘区所参与的 LUN 的 GUID。 因此,可以使用此方法的结果来确定驱动器贡献的 LUN 数,方法是对 ppExtentArray 中返回的不同 LunId 值进行计数。
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows Vista [仅限桌面应用] |
最低受支持的服务器 | Windows Server 2003 [仅限桌面应用] |
目标平台 | Windows |
标头 | vds.h |
Library | Uuid.lib |