Timer.Dispose Metode

Definisi

Merilis semua sumber daya yang digunakan oleh instans saat ini dari Timer.

Overload

Nama Deskripsi
Dispose()

Merilis semua sumber daya yang digunakan oleh instans saat ini dari Timer.

Dispose(WaitHandle)

Merilis semua sumber daya yang digunakan oleh instans Timer saat ini dan sinyal ketika timer telah dibuang.

Dispose()

Sumber:
Timer.cs
Sumber:
Timer.cs
Sumber:
Timer.cs
Sumber:
Timer.cs
Sumber:
Timer.cs

Merilis semua sumber daya yang digunakan oleh instans saat ini dari Timer.

public:
 virtual void Dispose();
public void Dispose();
abstract member Dispose : unit -> unit
override this.Dispose : unit -> unit
Public Sub Dispose ()

Penerapan

Contoh

Contoh kode berikut menunjukkan cara membebaskan sumber daya yang Timerdipegang oleh .

using System;
using System.Threading;

class TimerExample
{
    static void Main()
    {
        // Create an AutoResetEvent to signal the timeout threshold in the
        // timer callback has been reached.
        var autoEvent = new AutoResetEvent(false);
        
        var statusChecker = new StatusChecker(10);

        // Create a timer that invokes CheckStatus after one second, 
        // and every 1/4 second thereafter.
        Console.WriteLine("{0:h:mm:ss.fff} Creating timer.\n", 
                          DateTime.Now);
        var stateTimer = new Timer(statusChecker.CheckStatus, 
                                   autoEvent, 1000, 250);

        // When autoEvent signals, change the period to every half second.
        autoEvent.WaitOne();
        stateTimer.Change(0, 500);
        Console.WriteLine("\nChanging period to .5 seconds.\n");

        // When autoEvent signals the second time, dispose of the timer.
        autoEvent.WaitOne();
        stateTimer.Dispose();
        Console.WriteLine("\nDestroying timer.");
    }
}

class StatusChecker
{
    private int invokeCount;
    private int  maxCount;

    public StatusChecker(int count)
    {
        invokeCount  = 0;
        maxCount = count;
    }

    // This method is called by the timer delegate.
    public void CheckStatus(Object stateInfo)
    {
        AutoResetEvent autoEvent = (AutoResetEvent)stateInfo;
        Console.WriteLine("{0} Checking status {1,2}.", 
            DateTime.Now.ToString("h:mm:ss.fff"), 
            (++invokeCount).ToString());

        if(invokeCount == maxCount)
        {
            // Reset the counter and signal the waiting thread.
            invokeCount = 0;
            autoEvent.Set();
        }
    }
}
// The example displays output like the following:
//       11:59:54.202 Creating timer.
//       
//       11:59:55.217 Checking status  1.
//       11:59:55.466 Checking status  2.
//       11:59:55.716 Checking status  3.
//       11:59:55.968 Checking status  4.
//       11:59:56.218 Checking status  5.
//       11:59:56.470 Checking status  6.
//       11:59:56.722 Checking status  7.
//       11:59:56.972 Checking status  8.
//       11:59:57.223 Checking status  9.
//       11:59:57.473 Checking status 10.
//       
//       Changing period to .5 seconds.
//       
//       11:59:57.474 Checking status  1.
//       11:59:57.976 Checking status  2.
//       11:59:58.476 Checking status  3.
//       11:59:58.977 Checking status  4.
//       11:59:59.477 Checking status  5.
//       11:59:59.977 Checking status  6.
//       12:00:00.478 Checking status  7.
//       12:00:00.980 Checking status  8.
//       12:00:01.481 Checking status  9.
//       12:00:01.981 Checking status 10.
//       
//       Destroying timer.
Imports System.Threading

Public Module Example
    Public Sub Main()
        ' Use an AutoResetEvent to signal the timeout threshold in the
        ' timer callback has been reached.
        Dim autoEvent As New AutoResetEvent(False)

        Dim statusChecker As New StatusChecker(10)

        ' Create a timer that invokes CheckStatus after one second, 
        ' and every 1/4 second thereafter.
        Console.WriteLine("{0:h:mm:ss.fff} Creating timer." & vbCrLf, 
                          DateTime.Now)
        Dim stateTimer As New Timer(AddressOf statusChecker.CheckStatus, 
                                    autoEvent, 1000, 250)

        ' When autoEvent signals, change the period to every half second.
        autoEvent.WaitOne()
        stateTimer.Change(0, 500)
        Console.WriteLine(vbCrLf & "Changing period to .5 seconds." & vbCrLf)

        ' When autoEvent signals the second time, dispose of the timer.
        autoEvent.WaitOne()
        stateTimer.Dispose()
        Console.WriteLine(vbCrLf & "Destroying timer.")
    End Sub
End Module

Public Class StatusChecker
    Dim invokeCount, maxCount As Integer 

    Sub New(count As Integer)
        invokeCount  = 0
        maxCount = count
    End Sub

    ' The timer callback method.
    Sub CheckStatus(stateInfo As Object)
        Dim autoEvent As AutoResetEvent = DirectCast(stateInfo, AutoResetEvent)
        invokeCount += 1
        Console.WriteLine("{0:h:mm:ss.fff} Checking status {1,2}.", 
                          DateTime.Now, invokeCount)
        If invokeCount = maxCount Then
            ' Reset the counter and signal the waiting thread.
            invokeCount = 0
            autoEvent.Set()
        End If
    End Sub
End Class
' The example displays output like the following:
'       11:59:54.202 Creating timer.
'       
'       11:59:55.217 Checking status  1.
'       11:59:55.466 Checking status  2.
'       11:59:55.716 Checking status  3.
'       11:59:55.968 Checking status  4.
'       11:59:56.218 Checking status  5.
'       11:59:56.470 Checking status  6.
'       11:59:56.722 Checking status  7.
'       11:59:56.972 Checking status  8.
'       11:59:57.223 Checking status  9.
'       11:59:57.473 Checking status 10.
'       
'       Changing period to .5 seconds.
'       
'       11:59:57.474 Checking status  1.
'       11:59:57.976 Checking status  2.
'       11:59:58.476 Checking status  3.
'       11:59:58.977 Checking status  4.
'       11:59:59.477 Checking status  5.
'       11:59:59.977 Checking status  6.
'       12:00:00.478 Checking status  7.
'       12:00:00.980 Checking status  8.
'       12:00:01.481 Checking status  9.
'       12:00:01.981 Checking status 10.
'       
'       Destroying timer.

Keterangan

Dispose Panggilan memungkinkan sumber daya yang Timer digunakan oleh untuk dialokasikan untuk tujuan lain. Untuk informasi selengkapnya tentang Dispose, lihat Membersihkan Sumber Daya Yang Tidak Dikelola.

Note

Panggilan balik dapat terjadi setelah Dispose() metode kelebihan beban dipanggil, karena timer mengantrekan panggilan balik untuk eksekusi oleh utas kumpulan utas. Anda dapat menggunakan Dispose(WaitHandle) metode kelebihan beban untuk menunggu hingga semua panggilan balik selesai.

Lihat juga

Berlaku untuk

Dispose(WaitHandle)

Sumber:
Timer.cs
Sumber:
Timer.cs
Sumber:
Timer.cs
Sumber:
Timer.cs
Sumber:
Timer.cs

Merilis semua sumber daya yang digunakan oleh instans Timer saat ini dan sinyal ketika timer telah dibuang.

public:
 bool Dispose(System::Threading::WaitHandle ^ notifyObject);
public bool Dispose(System.Threading.WaitHandle notifyObject);
member this.Dispose : System.Threading.WaitHandle -> bool
Public Function Dispose (notifyObject As WaitHandle) As Boolean

Parameter

notifyObject
WaitHandle

Yang WaitHandle akan disinyalir ketika Timer telah dibuang.

Mengembalikan

true jika fungsi berhasil; jika tidak, false.

Pengecualian

Parameternya notifyObject adalah null.

Keterangan

Dispose Panggilan memungkinkan sumber daya yang Timer digunakan oleh untuk dialokasikan untuk tujuan lain. Untuk informasi selengkapnya tentang Dispose, lihat Membersihkan Sumber Daya Yang Tidak Dikelola.

Ketika metode ini selesai, metode ini memberi sinyal yang WaitHandle ditentukan oleh notifyObject parameter . Gunakan kelebihan beban Dispose metode ini jika Anda ingin dapat memblokir sampai Anda yakin bahwa timer telah dibuang. Timer tidak dibuang sampai semua panggilan balik yang saat ini diantrekan telah selesai.

Note

Jika panggilan balik menggunakan Change metode untuk mengatur dueTime parameter ke nol, kondisi balapan dapat terjadi ketika Dispose(WaitHandle) metode kelebihan beban dipanggil: Jika timer mengantre panggilan balik baru sebelum Dispose(WaitHandle) metode kelebihan beban mendeteksi bahwa tidak ada panggilan balik yang diantrekan, Dispose(WaitHandle) terus memblokir; jika tidak, timer dibuang saat panggilan balik baru sedang diantrekan, dan dilemparkan ObjectDisposedException ketika panggilan balik baru memanggil Change metode .

Lihat juga

Berlaku untuk