Process.Kill Metoda
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
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
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.