Process.HasExited Eigenschap
Definitie
Belangrijk
Bepaalde informatie heeft betrekking op een voorlopige productversie die aanzienlijk kan worden gewijzigd voordat deze wordt uitgebracht. Microsoft biedt geen enkele expliciete of impliciete garanties met betrekking tot de informatie die hier wordt verstrekt.
Hiermee wordt een waarde opgehaald die aangeeft of het bijbehorende proces is beëindigd.
public:
property bool HasExited { bool get(); };
[System.ComponentModel.Browsable(false)]
public bool HasExited { get; }
[<System.ComponentModel.Browsable(false)>]
member this.HasExited : bool
Public ReadOnly Property HasExited As Boolean
Waarde van eigenschap
trueals het besturingssysteemproces waarnaar wordt verwezen door het Process onderdeel is beëindigd; anders. false
- Kenmerken
Uitzonderingen
Er is geen proces gekoppeld aan het object.
De afsluitcode voor het proces kan niet worden opgehaald.
U probeert toegang te krijgen tot de HasExited eigenschap voor een proces dat wordt uitgevoerd op een externe computer. Deze eigenschap is alleen beschikbaar voor processen die worden uitgevoerd op de lokale computer.
Voorbeelden
In het volgende voorbeeld wordt een exemplaar van Kladblok gestart. Vervolgens wordt het fysieke geheugengebruik van het bijbehorende proces opgehaald met een interval van 2 seconden voor een maximum van 10 seconden. In het voorbeeld wordt gedetecteerd of het proces wordt afgesloten voordat 10 seconden zijn verstreken. In het voorbeeld wordt het proces gesloten als het nog steeds na 10 seconden wordt uitgevoerd.
using System;
using System.ComponentModel;
using System.Diagnostics;
using System.IO;
using System.Threading;
namespace ProcessSample
{
class MyProcessClass
{
public static void Main()
{
try
{
using (Process myProcess = Process.Start("Notepad.exe"))
{
// Display physical memory usage 5 times at intervals of 2 seconds.
for (int i = 0; i < 5; i++)
{
if (!myProcess.HasExited)
{
// Discard cached information about the process.
myProcess.Refresh();
// Print working set to console.
Console.WriteLine($"Physical Memory Usage: {myProcess.WorkingSet}");
// Wait 2 seconds.
Thread.Sleep(2000);
}
else
{
break;
}
}
// Close process by sending a close message to its main window.
myProcess.CloseMainWindow();
// Free resources associated with process.
myProcess.Close();
}
}
catch (Exception e) when (e is Win32Exception || e is FileNotFoundException)
{
Console.WriteLine("The following exception was raised: ");
Console.WriteLine(e.Message);
}
}
}
}
open System.ComponentModel
open System.Diagnostics
open System.IO
open System.Threading
try
use myProcess = Process.Start "Notepad.exe"
// Display physical memory usage 5 times at intervals of 2 seconds.
let mutable i = 0
while i < 5 && not myProcess.HasExited do
// Discard cached information about the process.
myProcess.Refresh()
// Print working set to console.
printfn $"Physical Memory Usage: {myProcess.WorkingSet64}"
// Wait 2 seconds.
Thread.Sleep 2000
i <- i + 1
// Close process by sending a close message to its main window.
myProcess.CloseMainWindow() |> ignore
// Free resources associated with process.
myProcess.Close()
with
| :? Win32Exception
| :? FileNotFoundException as e ->
printfn "The following exception was raised: "
printfn $"{e.Message}"
Imports System.ComponentModel
Imports System.Diagnostics
Imports System.IO
Imports System.Threading
Namespace Process_Sample
Class MyProcessClass
Public Shared Sub Main()
Try
Using myProcess = Process.Start("Notepad.exe")
' Display physical memory usage 5 times at intervals of 2 seconds.
Dim i As Integer
For i = 0 To 4
If Not myProcess.HasExited Then
' Discard cached information about the process.
myProcess.Refresh()
' Print working set to console.
Console.WriteLine($"Physical Memory Usage: {myProcess.WorkingSet}")
' Wait 2 seconds.
Thread.Sleep(2000)
Else
Exit For
End If
Next i
' Close process by sending a close message to its main window.
myProcess.CloseMainWindow()
' Free resources associated with process.
myProcess.Close()
End Using
Catch e As Exception When TypeOf e Is Win32Exception Or TypeOf e Is FileNotFoundException
Console.WriteLine("The following exception was raised: ")
Console.WriteLine(e.Message)
End Try
End Sub
End Class
End Namespace 'Process_Sample
Opmerkingen
Een waarde van true voor HasExited geeft aan dat het bijbehorende proces is beëindigd, normaal of abnormaal. U kunt het bijbehorende proces aanvragen of afdwingen door te bellen of Killaf te sluitenCloseMainWindow. Als een ingang is geopend voor het proces, geeft het besturingssysteem het procesgeheugen vrij wanneer het proces is afgesloten, maar behoudt het beheergegevens over het proces, zoals de ingang, afsluitcode en afsluittijd. Als u deze informatie wilt ophalen, kunt u de ExitCode en ExitTime eigenschappen gebruiken. Deze eigenschappen worden automatisch ingevuld voor processen die door dit onderdeel zijn gestart. De beheergegevens worden vrijgegeven wanneer alle Process onderdelen die aan het systeemproces zijn gekoppeld, worden vernietigd en geen ingangen meer bevatten voor het afgesloten proces.
Een proces kan onafhankelijk van uw code worden beëindigd. Als u het proces met dit onderdeel hebt gestart, werkt het systeem de waarde automatisch HasExited bij, zelfs als het bijbehorende proces onafhankelijk wordt afgesloten.
Note
Wanneer de standaarduitvoer is omgeleid naar asynchrone gebeurtenis-handlers, is het mogelijk dat uitvoerverwerking niet is voltooid wanneer deze eigenschap wordt geretourneerd true. Om ervoor te zorgen dat de asynchrone gebeurtenisafhandeling is voltooid, roept u de WaitForExit() overbelasting aan die geen parameter nodig heeft voordat u deze controleert HasExited.