Process.HasExited Vlastnost

Definice

Získá hodnotu označující, zda byl přidružený proces ukončen.

public:
 property bool HasExited { bool get(); };
public bool HasExited { get; }
[System.ComponentModel.Browsable(false)]
public bool HasExited { get; }
member this.HasExited : bool
[<System.ComponentModel.Browsable(false)>]
member this.HasExited : bool
Public ReadOnly Property HasExited As Boolean

Hodnota vlastnosti

Boolean

true pokud se proces operačního systému odkazovaný komponentou Process ukončil; v opačném případě false.

Atributy

Výjimky

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

Ukončovací kód procesu nelze načíst.

Pokoušíte se získat přístup k HasExited vlastnosti procesu, který běží na vzdáleném počítači. Tato vlastnost je dostupná pouze pro procesy spuštěné v místním počítači.

Příklady

Následující příklad spustí instanci Poznámkového bloku. Potom načte využití fyzické paměti přidruženého procesu v 2sekundových intervalech maximálně 10 sekund. Příklad zjistí, jestli proces skončí před 10 sekundami. Příklad proces zavře, pokud je stále spuštěný po 10 sekundách.

#using <System.dll>

using namespace System;
using namespace System::Diagnostics;
using namespace System::Threading;
int main()
{
   try
   {
      Process^ myProcess;
      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 : {0}", myProcess->WorkingSet.ToString() );
            
            // Wait 2 seconds.
            Thread::Sleep( 2000 );
         }
         else
         {
            break;
         }

      }
      myProcess->CloseMainWindow();
      
      // Free resources associated with process.
      myProcess->Close();
   }
   catch ( Exception^ e ) 
   {
      Console::WriteLine( "The following exception was raised: " );
      Console::WriteLine( e->Message );
   }

}
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);
            }
        }
    }
}
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

Poznámky

Hodnota true pro HasExited indikuje, že přidružený proces skončil, a to buď normálně, nebo neobvykle. Můžete požádat nebo vynutit ukončení přidruženého procesu voláním CloseMainWindow nebo Kill. Pokud je obslužný rutina otevřená pro proces, operační systém uvolní paměť procesu při ukončení procesu, ale zachová informace o procesu správy, jako je popisovač, ukončovací kód a čas ukončení. K získání těchto informací můžete použít ExitCode vlastnosti a ExitTime vlastnosti. Tyto vlastnosti se vyplní automaticky pro procesy, které tato komponenta spustila. Informace o správě se uvolní, když všechny Process komponenty, které jsou přidružené k systémovému procesu, budou zničeny a nebudou obsahovat žádné další popisovače pro ukončený proces.

Proces může ukončit nezávisle na vašem kódu. Pokud jste proces spustili pomocí této komponenty, systém aktualizuje hodnotu HasExited automaticky, i když přidružený proces skončí nezávisle.

Poznámka

Pokud byl standardní výstup přesměrován na asynchronní obslužné rutiny událostí, je možné, že výstupní zpracování nebude dokončeno, když tato vlastnost vrátí true. Chcete-li zajistit, aby bylo dokončeno asynchronní zpracování událostí, zavolejte WaitForExit() přetížení, které před kontrolou HasExitednepřebere žádný parametr .

Platí pro

Viz také