IVdsVolume::Shrink 方法 (vds.h)

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

减小卷的大小和所有 plexes,并将释放的盘区返回到可用空间。

Syntax

HRESULT Shrink(
  [in]  ULONGLONG ullNumberOfBytesToRemove,
  [out] IVdsAsync **ppAsync
);

参数

[in] ullNumberOfBytesToRemove

减少的大小(以字节为单位)。

[out] ppAsync

IVdsAsync 接口指针的地址。 VDS 在返回时初始化接口。 调用方必须释放接口。 使用此接口可以取消、等待或查询作的状态。 如果调用 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 提供程序 。 可能的返回值包括以下内容。

返回代码/值 Description
S_OK
该方法已成功完成。
VDS_E_PROVIDER_CACHE_CORRUPT
0x8004241FL
提供程序的缓存已损坏。 这表示提供程序内的软件或通信问题,用于缓存有关附加设备的信息。 调用方可以使用 IVdsHwProvider::Reenumerate 方法,后跟 IVdsHwProvider::Refresh 方法还原缓存。
VDS_E_CANNOT_SHRINK
0x8004251EL
卷无法收缩,因为文件系统不支持它。
VDS_E_DISK_REMOVEABLE
0x8004255AL
可移动媒体不支持此作。
VDS_E_SHRINK_SIZE_LESS_THAN_MIN
0x80042573L
指定的收缩大小小于允许的最小收缩大小。
VDS_E_SHRINK_SIZE_TOO_BIG
0x80042574L
指定的收缩大小太大,导致卷小于最小卷大小。

注解

此方法是 IVdsVolumeShrink::Shrink 方法的包装器。 如果调用 IVdsVolume::Shrink则 uNumberOfBytesToRemove 参数的值用于 IVdsVolumeShrink::ShrinkullDesiredNumberOfReclaimableBytesullMinNumberOfReclaimableBytes 参数。

仅 NTFS 和 RAW 卷支持收缩和 扩展 作。

使用此方法收缩文件系统和卷。 如果 VDS 无法收缩卷,则会停止作,而不会收缩文件系统。

每个卷一次只能执行一个收缩或碎片整理作。Windows Server 2008 和 Windows Vista: 计算机上一次只能执行一个收缩或碎片整理作。

如果 uNumberOfBytesToRemove 为零,该方法将失败。 否则,VDS 会将 uNumberOfBytesToRemove 舍入为文件系统群集大小的倍数。

实现者必须返回指向此方法 的 IVdsAsync 接口的指针,即使调用未启动异步作。

可以使用 IVdsVolumeShrink::QueryMaxReclaimableBytes 方法估计收缩作要回收的字节数。 但是, QueryMaxReclaimableBytes 可以返回比实际可用的字节多。

要求

Requirement 价值
最低支持的客户端 Windows Vista [仅限桌面应用]
支持的最低服务器 Windows Server 2008 [仅限桌面应用]
目标平台 Windows操作系统
Header vds.h
Library Uuid.lib

另请参阅

IVdsAsync

IVdsVolume

IVdsVolume::Extend