Megosztás a következőn keresztül:


Measure-Command

Méri a szkriptblokkok és parancsmagok futtatásához szükséges időt.

Syntax

Default (Alapértelmezett)

Measure-Command
    [-InputObject <PSObject>]
    [-Expression] <ScriptBlock>
    [<CommonParameters>]

Description

A Measure-Command parancsmag belsőleg futtat egy szkriptblokkot vagy parancsmagot, méri a művelet végrehajtási idejét, és visszaadja azt.

Megjegyzés:

A Measure-Command által futtatott szkriptblokkok az aktuális hatókörben futnak, nem gyermekhatókörben.

Példák

1. példa: Parancs mérése

Ez a példa egy Get-EventLog parancs futtatásához szükséges időt méri, amely lekéri az eseményeket a Windows PowerShell eseménynaplójában.

Measure-Command { Get-EventLog "Windows PowerShell" }

A 2. példa: Hasonlíts össze két kimenetet Measure-Command-ból

Az első parancs egy rekurzív Get-ChildItem-parancs feldolgozásához szükséges időt méri, amely a Path paramétert használja, hogy csak .txt fájlokat szerezzen be a C:\Windows könyvtárban és annak alkönyvtáraiban.

A második parancs egy rekurzív Get-ChildItem-parancs feldolgozásához szükséges időt méri, amely a szolgáltatóspecifikus Szűrő paramétert használja.

Ezek a parancsok egy szolgáltatóspecifikus szűrő használatát mutatják be a PowerShell-parancsokban.

Measure-Command { Get-ChildItem -Path C:\Windows\*.txt -Recurse }
Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 8
Milliseconds      : 618
Ticks             : 86182763
TotalDays         : 9.9748568287037E-05
TotalHours        : 0.00239396563888889
TotalMinutes      : 0.143637938333333
TotalSeconds      : 8.6182763
TotalMilliseconds : 8618.2763
Measure-Command {Get-ChildItem C:\Windows -Filter "*.txt" -Recurse}
Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 1
Milliseconds      : 140
Ticks             : 11409189
TotalDays         : 1.32050798611111E-05
TotalHours        : 0.000316921916666667
TotalMinutes      : 0.019015315
TotalSeconds      : 1.1409189
TotalMilliseconds : 1140.9189

3. példa: Bemenet irányítása Measure-Command-ra

A Measure-Command felé csövezhető objektumok a Expression paraméternek átadott szkriptblokk számára érhetők el. A szkriptblokkot a rendszer egyszer hajtja végre a folyamat minden objektumához.

# Perform a simple operation to demonstrate the InputObject parameter
# Note that no output is displayed.
10, 20, 50 | Measure-Command -Expression { for ($i=0; $i -lt $_; $i++) {$i} }
Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 0
Milliseconds      : 12
Ticks             : 122672
TotalDays         : 1.41981481481481E-07
TotalHours        : 3.40755555555556E-06
TotalMinutes      : 0.000204453333333333
TotalSeconds      : 0.0122672
TotalMilliseconds : 12.2672

4. példa: A mért parancs kimenetének megjelenítése

A kifejezés kimenetének megjelenítéséhez Measure-Command-ben, használhat egy csővezetéket Out-Default-be.

# Perform the same operation as above adding Out-Default to every execution.
# This will show that the ScriptBlock is in fact executing for every item.
10, 20, 50 | Measure-Command -Expression {for ($i=0; $i -lt $_; $i++) {$i}; "$($_)" | Out-Default }
10
20
50


Days              : 0
Hours             : 0
Minutes           : 0
Seconds           : 0
Milliseconds      : 11
Ticks             : 113745
TotalDays         : 1.31649305555556E-07
TotalHours        : 3.15958333333333E-06
TotalMinutes      : 0.000189575
TotalSeconds      : 0.0113745
TotalMilliseconds : 11.3745

5. példa: Végrehajtás mérése gyermekhatókörben

Measure-Command futtatja a szkriptblokkot az aktuális hatókörben, így a szkriptblokk módosíthatja az aktuális hatókör értékeit. Az aktuális hatókör módosításainak elkerülése érdekében a szkriptblokkot kapcsos zárójelekbe ({}) kell csomagolnia, és a meghívási operátorral (&) kell végrehajtania a blokkot egy gyermekhatókörben.

$foo = 'Value 1'
$null = Measure-Command { $foo = 'Value 2' }
$foo
$null = Measure-Command { & { $foo = 'Value 3' } }
$foo
Value 2
Value 2

A meghívási operátorral kapcsolatos további információkért lásd: about_Operators.

Paraméterek

-Expression

Az időzítés alatt álló kifejezést adja meg. A kifejezést kapcsos zárójelekbe ({}) csatolja.

Paramétertulajdonságok

Típus:ScriptBlock
Alapértelmezett érték:None
Támogatja a helyettesítő karaktereket:False
DontShow:False

Paraméterkészletek

(All)
Position:0
Kötelező:True
Folyamatból származó érték:False
Folyamatból származó érték tulajdonságnév alapján:False
Fennmaradó argumentumokból származó érték:False

-InputObject

Az InputObject paraméterhez kötött objektumok nem kötelező bemenetek a Kifejezés paraméternek átadott szkriptblokkhoz. A szkriptblokkon belül $_ használható a folyamat aktuális objektumára való hivatkozásra.

Paramétertulajdonságok

Típus:PSObject
Alapértelmezett érték:None
Támogatja a helyettesítő karaktereket:False
DontShow:False

Paraméterkészletek

(All)
Position:Named
Kötelező:False
Folyamatból származó érték:True
Folyamatból származó érték tulajdonságnév alapján:False
Fennmaradó argumentumokból származó érték:False

CommonParameters

Ez a parancsmag a következő gyakori paramétereket támogatja: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutBuffer, -OutVariable, -PipelineVariable, -ProgressAction, -Verbose, -WarningAction és -WarningVariable. További információért lásd about_CommonParameters.

Bevitelek

PSObject

Ehhez a parancsmaghoz csövezhet objektumot.

Kimenetek

TimeSpan

Ez a parancsmag egy időtartam-objektumot ad vissza, amely az eredményt képviseli.