IVdsVolumeMF::Format 方法 (vds.h)
[從Windows 8和Windows Server 2012開始,虛擬磁碟服務COM 介面會由Windows 儲存體管理 API取代。
格式化目前磁片區上的檔案系統。
語法
HRESULT Format(
[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] 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 提供者 。 可能的傳回值包括下列專案。
傳回碼/值 | 描述 |
---|---|
|
檔案系統已順利格式化。 |
|
如果呼叫端嘗試格式化系統、開機、損毀傾印、休眠或分頁檔磁片區,作業就會遭到拒絕。 |
|
磁片區失敗。 |
|
無法存取包含磁片區的套件。 離線套件中的所有磁片區都無法存取。 |
此外, IVdsAsync 介面可以傳回下列相關的警告和錯誤碼。
傳回碼/值 | 描述 |
---|---|
|
檔案系統已格式化,但未壓縮。 |
|
檔案系統不相容。 |
|
媒體不相容。 |
|
存取遭到拒絕。 |
|
媒體受到寫入保護。 |
|
標籤無效。 |
|
磁片區無法快速格式化。 |
|
格式期間發生 IO 錯誤。 |
|
磁片區大小太小而無法格式化。 |
|
磁片區大小太大而無法格式化。 |
|
叢集大小太小,無法允許格式化。 |
|
叢集大小太大,無法允許格式化。 |
|
叢集數目太大,無法以 32 位整數表示。 |
|
類型參數的值不是VDS_FST_NTFS、VDS_FST_FAT、VDS_FST_FAT32或VDS_FST_UDF。 |
|
無法停用磁片區的 BitLocker 加密。 |
備註
若要在動態磁碟上建立開機磁片區,您必須先呼叫 IVdsVolume::SetFlags 來設定 VDS_VF_INSTALLABLE 旗標,再呼叫 Format 來格式化磁片區。
如果 OEM 磁碟分割格式化為 FAT 或 FAT32,則資料分割類型不會變更。 如果格式化為 NTFS,則分割區類型會變更為 PARTITION_IFS (0x07) 。 如需資料分割類型的相關資訊,請參閱 CREATE_PARTITION_PARAMETERS。
如果針對受 BitLocker 完整磁片區加密保護的磁片區呼叫這個方法,則會停用磁片區的 BitLocker 加密,直到使用者重新啟用它為止。
如需檔案系統限制的詳細資訊,例如最小和最大配置單位大小 (也稱為叢集大小) ,請參閱 NTFS 技術參考 和 FAT 技術參考。
規格需求
最低支援的用戶端 | Windows Vista [僅限傳統型應用程式] |
最低支援的伺服器 | Windows Server 2003 [僅限傳統型應用程式] |
目標平臺 | Windows |
標頭 | vds.h |
程式庫 | Uuid.lib |