Measure-Command

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

Syntax

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

Description

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

Feljegyzés

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

Példák

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

Ez a példa egy parancs futtatásához Get-EventLog 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" }

2. példa: A Measure-Command két kimenetének összehasonlítása

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

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

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: Piping input to Measure-Command

A rendszer a Kifejezés paraméternek Measure-Command átadott szkriptblokk számára elérhető objektumokat továbbítja. 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 Measure-Command kimenetének megjelenítéséhez használhatja a csövet.Out-Default

# 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 burkolnia, é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őtúllépés alatt álló kifejezést adja meg. Csatolja a kifejezést kapcsos zárójelekbe ({}).

Type:ScriptBlock
Position:0
Default value:None
Required:True
Accept pipeline input:False
Accept wildcard characters: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 a folyamat aktuális objektumára hivatkozhat.

Type:PSObject
Position:Named
Default value:None
Required:False
Accept pipeline input:True
Accept wildcard characters:False

Bevitelek

PSObject

Ehhez a parancsmaghoz csövezhet objektumot.

Kimenetek

TimeSpan

Ez a parancsmag egy időtúllépési objektumot ad vissza, amely az eredményt jelöli.