共用方式為


ResizeVirtualHardDisk 方法Msvm_ImageManagementService類別

調整現有的虛擬硬碟大小。 虛擬硬碟必須離線。 如需此方法的使用限制,請參閱。

語法

uint32 ResizeVirtualHardDisk(
  [in]  string              Path,
  [in]  uint64              MaxInternalSize,
  [out] CIM_ConcreteJob REF Job
);

參數

路徑 [in]

類型: 字串

虛擬硬碟檔案的完整路徑。

MaxInternalSize [in]

類型: uint64

虛擬機器可檢視的虛擬硬碟大小上限,以位元組為單位。 MaxInternalSize 最小值為 DiskSize + 512 - (DiskSize mod 512) 。 DiskSize 是虛擬硬碟檔案的大小,以位元組為單位。 如果指定的 MaxInternalSize 值小於最小值,則會傳回 InvalidParameter 錯誤 (32773) 。

作業 [out]

類型: CIM_ConcreteJob

如果作業是以非同步方式執行,這個方法會傳回 4096,而此參數將包含衍生自 CIM_ConcreteJob之物件的參考。

傳回值

類型: uint32

這個方法可以傳回下列其中一個值。

已完成,沒有錯誤 (0)

已檢查方法參數 - 作業啟動 (4096)

失敗 (32768)

拒絕存取 (32769)

不支援 (32770)

狀態未知 , (32771)

時 (32772)

不正確參數 (32773)

系統正在使用 中 (32774)

此作業的狀態無效 , (32775)

不正確的資料類型 (32776)

( 32777) 無法使用系統

記憶體不足 (32778)

找不到 檔案 (32779)

備註

當虛擬硬碟的大小增加時,只能搭配此方法使用下列類型的虛擬硬碟:

  • 已修正 VHD
  • 已修正 VHDX
  • 動態 VHD
  • 動態 VHDX
  • 差異 VHDX

當虛擬硬碟的大小減少時,只能搭配此方法使用下列類型的虛擬硬碟:

  • 已修正 VHDX
  • 動態 VHDX
  • 差異 VHDX

Msvm_ImageManagementService類別的存取可能會受限於 UAC 篩選。 如需詳細資訊,請參閱 使用者帳戶控制和 WMI

範例

下列 C# 範例會展開虛擬硬碟檔案。 您可以在虛擬 範例的常見公用程式中找到參考的公用程式, (V2)

const UInt64 size1G = 0x40000000;

public static void ResizeVirtualHardDisk(string path, UInt64 maxInternalSize)
{
    ManagementScope scope = new ManagementScope(@"root\virtualization\V2", null);
    ManagementObject imageService = Utility.GetServiceObject(scope, "Msvm_ImageManagementService");

    ManagementBaseObject inParams = imageService.GetMethodParameters("ResizeVirtualHardDisk");
    inParams["Path"] = path;
    inParams["MaxInternalSize"] = maxInternalSize * size1G;
    ManagementBaseObject outParams = imageService.InvokeMethod("ResizeVirtualHardDisk", inParams, null);
    if ((UInt32)outParams["ReturnValue"] == ReturnCode.Started)
    {
        if (Utility.JobCompleted(outParams, scope))
        {
            Console.WriteLine("{0} was resized successfully.", inParams["Path"]);
        }
        else
        {
            Console.WriteLine("Unable to resize {0}", inParams["Path"]);
        }
    }

    outParams.Dispose();
    inParams.Dispose();
    imageService.Dispose();
}

規格需求

需求
最低支援的用戶端
Windows 8 [僅限傳統型應用程式]
最低支援的伺服器
Windows Server 2012 [僅限傳統型應用程式]
命名空間
Root\Virtualization\V2
MOF
WindowsVirtualization.V2.mof
DLL
Vmms.exe

另請參閱

CIM_ConcreteJob

Msvm_ImageManagementService