Process.HasExited Özellik

Tanım

İlişkili işlemin sonlandırılıp sonlandırılmadığını belirten bir değer alır.

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

Özellik Değeri

true bileşen tarafından Process başvuruda bulunan işletim sistemi işlemi sonlandırıldıysa; sonlandırılmamışsa, false.

Öznitelikler

Özel durumlar

Nesneyle ilişkilendirilmiş bir işlem yok.

İşlemin çıkış kodu alınamadı.

Uzak bilgisayarda çalışan bir işlemin özelliğine HasExited erişmeye çalışıyorsunuz. Bu özellik yalnızca yerel bilgisayarda çalışan işlemler için kullanılabilir.

Örnekler

Aşağıdaki örnek bir Not Defteri örneği başlatır. Ardından, ilişkili işlemin fiziksel bellek kullanımını en fazla 10 saniye boyunca 2 saniyelik aralıklarla alır. Örnek, işlemin 10 saniye geçmeden çıkıp çıkmadığını algılar. Örnek, 10 saniye sonra hala çalışıyorsa işlemi kapatır.

#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

Açıklamalar

değeri true , HasExited ilişkili işlemin normal veya anormal şekilde sonlandırıldığını gösterir. veya öğesini çağırarak CloseMainWindow ilişkili işlemin çıkışını isteyebilir veya Killzorlayabilirsiniz. bir tanıtıcı işleme açıksa, işlemden çıkıldığında işletim sistemi işlem belleğini serbest bırakır, ancak tanıtıcı, çıkış kodu ve çıkış zamanı gibi işlemle ilgili yönetim bilgilerini korur. Bu bilgileri almak için ve ExitTime özelliklerini kullanabilirsinizExitCode. Bu özellikler, bu bileşen tarafından başlatılan işlemler için otomatik olarak doldurulur. Yönetim bilgileri, sistem işlemiyle ilişkili tüm Process bileşenler yok edildiğinde ve çıkış işlemine başka tanıtıcı tutmadığında serbest bırakılır.

Bir işlem kodunuzdan bağımsız olarak sonlandırılabilir. İşlemi bu bileşeni kullanarak başlattıysanız, ilişkili işlem bağımsız olarak çıksa bile sistem değerini HasExited otomatik olarak güncelleştirir.

Not

Standart çıkış zaman uyumsuz olay işleyicilerine yeniden yönlendirildiğinde, bu özellik döndürdüğünde trueçıkış işleme tamamlanmamış olabilir. Zaman uyumsuz olay işlemenin tamamlandığından emin olmak için, denetlemeden HasExitedönce parametresiz aşırı yüklemeyi çağırınWaitForExit().

Şunlara uygulanır

Ayrıca bkz.