Share via


IVdsAdvancedDisk::FormatPartition 方法 (vds.h)

[從 Windows 8 和 Windows Server 2012 開始,虛擬磁碟服務 COM 介面會由 Windows 記憶體管理 API 取代。

格式化現有的 OEM、ESP 或未知的數據分割。

語法

HRESULT FormatPartition(
  [in]  ULONGLONG            ullOffset,
  [in]  VDS_FILE_SYSTEM_TYPE type,
  [in]  LPWSTR               pwszLabel,
  [in]  DWORD                dwUnitAllocationSize,
  [in]  BOOL                 bForce,
  [in]  BOOL                 bQuickFormat,
  [in]  BOOL                 bEnableCompression,
  [out] IVdsAsync            **ppAsync
);

參數

[in] ullOffset

分割區位移。

[in] type

VDS_FILE_SYSTEM_TYPE列舉值,指定要使用的文件系統。 必須是下列其中一項:VDS_FST_NTFS、VDS_FST_FAT、VDS_FST_FAT32或VDS_FST_UDF。

[in] pwszLabel

表示磁碟區標籤的字串。

[in] dwUnitAllocationSize

以位元組為單位的文件系統配置單位大小,通常介於512和65536之間。

[in] bForce

如果 為TRUE,即使使用中,分割區也會格式化;否則,作業會失敗。

[in] bQuickFormat

如果 TRUE,VDS 會執行快速格式。 快速格式不會驗證磁碟區上的每個扇區。

[in] bEnableCompression

如果 為 TRUE,請在新格式化的檔案系統上啟用壓縮。 壓縮是NTFS的功能,無法設定FAT和FAT32檔系統。

[out] ppAsync

IVdsAsync 介面指標的位址,VDS 會在傳回時初始化。 呼叫端必須釋放 介面。 使用此指標來取消、等候或查詢作業的狀態。

傳回值

這個方法可以傳回標準 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 VDS 特定的傳回值。 它也可以使用 HRESULT_FROM_WIN32 宏傳回已轉換的系統錯誤碼。 錯誤可能來自 VDS 本身,或來自正在使用的基礎 VDS 提供者 。 可能的傳回值包括下列專案。

傳回碼/值 描述
S_OK
已成功格式化數據分割。
VDS_E_INVALID_OPERATION
0x80042415L
磁碟是卸除式磁碟,或者磁碟分區不是 OEM、ESP 或未知類型。
VDS_E_OBJECT_NOT_FOUND
0x80042405L
數據分割不存在。

備註

VDS 會實作這個方法。

此方法只會格式化 OEM、ESP 和未知的數據分割。 對於其他分割區,您必須改用 IVdsVolumeMF::FormatIVdsVolumeMF2::FormatEx 方法來格式化對應的磁碟區。 請注意,OEM、ESP 和未知的數據分割不會公開為磁碟區,因此無法使用 FormatFormatEx 格式化

這個方法無法用來格式化卸除式媒體。

如需文件系統限制的相關信息,例如最小和最大配置單位大小 (也稱為叢集大小) ,請參閱 NTFS技術參考FAT技術參考

如果 OEM 磁碟分區格式化為 FAT 或 FAT32,則數據分割類型不會變更。 如果格式化為NTFS,則分割區類型會變更為 PARTITION_IFS (0x07) 。 如需數據分割類型的相關信息,請參閱 CREATE_PARTITION_PARAMETERS

規格需求

需求
最低支援的用戶端 Windows Vista [僅限傳統型應用程式]
最低支援的伺服器 Windows Server 2003 [僅限傳統型應用程式]
目標平台 Windows
標頭 vds.h
程式庫 Uuid.lib

另請參閱

Disk 物件

IVdsAdvancedDisk

IVdsAsync

IVdsDiskPartitionMF::FormatPartitionEx

VDS_FILE_SYSTEM_TYPE