Sdílet prostřednictvím


Process.HasExited Vlastnost

Definice

Získá hodnotu označující, zda přidružený proces byl 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

true pokud se proces operačního systému, na který komponenta Process odkazuje, falseukončil, jinak .

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 HasExited k vlastnosti pro proces, který je spuštěn na vzdáleném počítači. Tato vlastnost je k dispozici 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. Poté načte využití fyzické paměti přidruženého procesu ve 2sekundových intervalech po dobu maximálně 10 sekund. Příklad zjistí, jestli se proces ukončí před uplynutím 10 sekund. Příklad zavře proces, pokud je stále spuštěný i 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 for HasExited označuje, že přidružený proces byl normálně nebo neobvykle ukončen. Můžete požádat nebo vynutit ukončení přidruženého procesu voláním CloseMainWindow nebo Kill. Pokud je pro proces otevřený popisovač, operační systém uvolní paměť procesu při ukončení procesu, ale zachová informace o správě procesu, 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 . Tyto vlastnosti se vyplní automaticky pro procesy spuštěné touto komponentou. Informace o správě jsou uvolněny, když jsou zničeny všechny Process součásti, které jsou přidruženy k systémovému procesu a neobsahují žádné další popisovače pro ukončený proces.

Proces může být ukončen nezávisle na kódu. Pokud jste proces spustili pomocí této komponenty, systém aktualizuje hodnotu HasExited automaticky, a to i v případě, že se přidružený proces nezávisle ukončí.

Poznámka

Pokud byl standardní výstup přesměrován na asynchronní obslužné rutiny událostí, je možné, že zpracování výstupu nebude dokončeno, když tato vlastnost vrátí true. Pokud chcete zajistit dokončení asynchronního zpracování událostí, před kontrolou WaitForExit()HasExitedzavolejte přetížení, které nepřijímá žádný parametr.

Platí pro

Viz také