Sdílet prostřednictvím


Process.Kill Metoda

Definice

Vynutí ukončení základního procesu.

Přetížení

Kill()

Přidružený proces se okamžitě zastaví.

Kill(Boolean)

Okamžitě zastaví přidružený proces a volitelně jeho podřízené/podřízené procesy.

Poznámky

Metoda Kill vynutí ukončení procesu, zatímco CloseMainWindow pouze vyžaduje ukončení. Při provádění procesu s grafickým rozhraním je jeho smyčka zpráv ve stavu čekání. Smyčka zpráv se spustí pokaždé, když operační systém odešle do procesu zprávu systému Windows. Volání CloseMainWindow odešle požadavek na zavření hlavního okna, který v aplikaci ve správném formátu zavře podřízená okna a odvolá všechny spuštěné smyčky zpráv pro aplikaci. Požadavek na ukončení procesu voláním CloseMainWindow nevynutí ukončení aplikace. Aplikace může před ukončením požádat o ověření uživatele nebo může odmítnout ukončení. Pokud chcete vynutit ukončení aplikace, použijte metodu Kill .

Chování je stejné jako chování CloseMainWindow uživatele, který zavře hlavní okno aplikace pomocí systémové nabídky. Proto požadavek na ukončení procesu zavřením hlavního okna nenutí aplikaci okamžitě ukončit.

Poznámka

Metoda provádí Kill asynchronně. Po volání Kill metody zavolejte metodu WaitForExit , aby se počkalo na ukončení procesu, nebo zkontrolujte HasExited vlastnost a zjistěte, zda byl proces ukončen.

Poznámka

Metoda WaitForExit a HasExited vlastnost neodráží stav následnických procesů. Kdy Kill(entireProcessTree: true) se použije, a HasExited bude indikovat, WaitForExit že ukončení bylo dokončeno po ukončení daného procesu, a to i v případě, že všichni potomci ještě neukončili.

Data upravená procesem nebo prostředky přidělené procesu mohou být ztraceny, pokud zavoláte Kill. Kill způsobuje neobvyklé ukončení procesu a měl by být používán pouze v případě potřeby. CloseMainWindow umožňuje spořádané ukončení procesu a zavře všechna okna, takže je vhodnější pro aplikace s rozhraním. Pokud CloseMainWindow selže, můžete proces ukončit pomocí příkazu Kill . Kill je jediný způsob, jak ukončit procesy, které nemají grafická rozhraní.

Můžete volat Kill a CloseMainWindow pouze pro procesy, které jsou spuštěny v místním počítači. Nelze způsobit ukončení procesů ve vzdálených počítačích. Můžete zobrazit pouze informace o procesech spuštěných ve vzdálených počítačích.

Kill()

Zdroj:
Process.Unix.cs
Zdroj:
Process.Unix.cs
Zdroj:
Process.Unix.cs

Přidružený proces se okamžitě zastaví.

public:
 void Kill();
public void Kill ();
[System.Runtime.Versioning.UnsupportedOSPlatform("ios")]
[System.Runtime.Versioning.UnsupportedOSPlatform("tvos")]
public void Kill ();
[System.Runtime.Versioning.UnsupportedOSPlatform("ios")]
[System.Runtime.Versioning.UnsupportedOSPlatform("tvos")]
[System.Runtime.Versioning.SupportedOSPlatform("maccatalyst")]
public void Kill ();
member this.Kill : unit -> unit
[<System.Runtime.Versioning.UnsupportedOSPlatform("ios")>]
[<System.Runtime.Versioning.UnsupportedOSPlatform("tvos")>]
member this.Kill : unit -> unit
[<System.Runtime.Versioning.UnsupportedOSPlatform("ios")>]
[<System.Runtime.Versioning.UnsupportedOSPlatform("tvos")>]
[<System.Runtime.Versioning.SupportedOSPlatform("maccatalyst")>]
member this.Kill : unit -> unit
Public Sub Kill ()
Atributy

Výjimky

Přidružený proces nelze ukončit.

Pokoušíte se volat Kill() proces, který je spuštěn na vzdáleném počítači. Metoda je k dispozici pouze pro procesy spuštěné v místním počítači.

K tomuto Process objektu není přidružen žádný proces.

Viz také

Platí pro

Kill(Boolean)

Zdroj:
Process.NonUap.cs
Zdroj:
Process.NonUap.cs
Zdroj:
Process.NonUap.cs

Okamžitě zastaví přidružený proces a volitelně jeho podřízené/podřízené procesy.

public:
 void Kill(bool entireProcessTree);
public void Kill (bool entireProcessTree);
[System.Runtime.Versioning.UnsupportedOSPlatform("ios")]
[System.Runtime.Versioning.UnsupportedOSPlatform("tvos")]
public void Kill (bool entireProcessTree);
[System.Runtime.Versioning.UnsupportedOSPlatform("ios")]
[System.Runtime.Versioning.UnsupportedOSPlatform("tvos")]
[System.Runtime.Versioning.SupportedOSPlatform("maccatalyst")]
public void Kill (bool entireProcessTree);
member this.Kill : bool -> unit
[<System.Runtime.Versioning.UnsupportedOSPlatform("ios")>]
[<System.Runtime.Versioning.UnsupportedOSPlatform("tvos")>]
member this.Kill : bool -> unit
[<System.Runtime.Versioning.UnsupportedOSPlatform("ios")>]
[<System.Runtime.Versioning.UnsupportedOSPlatform("tvos")>]
[<System.Runtime.Versioning.SupportedOSPlatform("maccatalyst")>]
member this.Kill : bool -> unit
Public Sub Kill (entireProcessTree As Boolean)

Parametry

entireProcessTree
Boolean

true zabít přidružený proces a jeho potomky; false a ukončete pouze přidružený proces.

Atributy

Výjimky

Přidružený proces nelze ukončit.

-nebo-

Proces se ukončuje.

Pokoušíte se volat Kill() proces, který je spuštěn na vzdáleném počítači. Metoda je k dispozici pouze pro procesy spuštěné v místním počítači.

Pouze .NET Framework a .NET Core 3.0 a starší verze: Proces už byl ukončen.

-nebo-

K tomuto Process objektu není přidružen žádný proces.

-nebo-

Volající proces je členem stromu potomků přidruženého procesu.

Ne všechny procesy ve stromu potomků přidruženého procesu je možné ukončit.

Poznámky

Pokud entireProcessTree je nastavená hodnota true, procesy, ve kterých volání nemá oprávnění k zobrazení podrobností, proces ukončení potomku tiše přeskočí, protože proces ukončení nemůže určit, jestli jsou tyto procesy potomky.

Viz také

Platí pro