Wait-Process
Väntar på att processerna ska stoppas innan fler indata accepteras.
Syntax
Wait-Process
[-Name] <String[]>
[[-Timeout] <Int32>]
[<CommonParameters>]
Wait-Process
[-Id] <Int32[]>
[[-Timeout] <Int32>]
[<CommonParameters>]
Wait-Process
[[-Timeout] <Int32>]
-InputObject <Process[]>
[<CommonParameters>]
Description
Cmdleten Wait-Process
väntar på att en eller flera processer som körs ska stoppas innan indata accepteras. I PowerShell-konsolen undertrycker den här cmdleten kommandotolken tills processerna har stoppats. Du kan ange en process efter processnamn eller process-ID (PID) eller skicka ett processobjekt till Wait-Process
.
Wait-Process
fungerar bara på processer som körs på den lokala datorn.
Exempel
Exempel 1: Stoppa en process och vänta
PS C:\> $nid = (Get-Process notepad).id
PS C:\> Stop-Process -Id $nid
PS C:\> Wait-Process -Id $nid
Det här exemplet stoppar anteckningar och väntar sedan på att processen ska stoppas innan den fortsätter med nästa kommando.
Det första kommandot använder cmdleten Get-Process
för att hämta ID:t för Anteckningar-processen. ID:t lagras i variabeln $nid
.
Det andra kommandot använder cmdleten Stop-Process
för att stoppa processen med det ID som lagras i $nid
.
Det tredje kommandot använder Wait-Process
för att vänta tills Anteckningar-processen har stoppats. Den använder ID-parameternWait-Process
för för att identifiera processen.
Exempel 2: Ange en process
PS C:\> $p = Get-Process notepad
PS C:\> Wait-Process -Id $p.id
PS C:\> Wait-Process -Name "notepad"
PS C:\> Wait-Process -InputObject $p
Dessa kommandon visar tre olika metoder för att ange en process till Wait-Process
. Det första kommandot hämtar Anteckningar-processen och lagrar den i variabeln $p
.
Det andra kommandot använder parametern Id , det tredje kommandot använder parametern Name och det fjärde kommandot använder parametern InputObject .
Dessa kommandon har samma resultat och kan användas synonymt.
Exempel 3: Vänta på processer under en angiven tid
PS C:\> Wait-Process -Name outlook, winword -Timeout 30
Det här kommandot väntar 30 sekunder på att Outlook- och Winword-processerna ska stoppas. Om båda processerna inte stoppas visar cmdleten ett icke-avslutande fel och kommandotolken.
Parametrar
-Id
Anger process-ID:t för processerna. Om du vill ange flera ID:t använder du kommatecken för att separera ID:t.
Om du vill hitta PID för en process skriver du Get-Process
.
Type: | Int32[] |
Aliases: | PID, ProcessId |
Position: | 0 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-InputObject
Anger processerna genom att skicka processobjekt. Ange en variabel som innehåller processobjekten eller skriv ett kommando eller uttryck som hämtar processobjekten, till exempel cmdleten Get-Process
.
Type: | Process[] |
Position: | Named |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Name
Anger processnamnen för processerna. Om du vill ange flera namn använder du kommatecken för att avgränsa namnen. Jokertecken stöds inte.
Type: | String[] |
Aliases: | ProcessName |
Position: | 0 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Timeout
Anger den maximala tid i sekunder som den här cmdleten väntar på att de angivna processerna ska stoppas. När det här intervallet går ut visar kommandot ett icke-avslutande fel som visar de processer som fortfarande körs och avslutar väntetiden. Som standard finns det ingen tidsgräns.
Type: | Int32 |
Aliases: | TimeoutSec |
Position: | 1 |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
Indata
Du kan skicka ett processobjekt till den här cmdleten.
Utdata
None
Denna cmdlet genererar inga utdata.
Kommentarer
Cmdleten stöds endast på Windows-plattformar.
Den här cmdleten använder metoden WaitForExit i klassen System.Diagnostics.Process .