Timer.Enabled Özellik

Tanım

öğesinin olayı tetikleyip tetiklemeyeceğini TimerElapsed belirten bir değer alır veya ayarlar.

public bool Enabled { get; set; }
[System.Timers.TimersDescription("TimerEnabled")]
public bool Enabled { get; set; }

Özellik Değeri

true olayı Timer tetiklerse Elapsed ; aksi takdirde , false. Varsayılan değer: false.

Öznitelikler

Özel durumlar

Zamanlayıcı atıldığından bu özellik ayarlanamıyor.

Özelliği, Interval zamanlayıcı etkinleştirilmeden önce Int32.MaxValue değerinden büyük bir değere ayarlanmıştır.

Örnekler

Aşağıdaki örnek, iki saniyede bir Timer (2000 milisaniye) olayını başlatan Timer.Elapsed , olay için bir olay işleyicisi ayarlayan ve zamanlayıcıyı başlatan bir nesnenin örneğini oluşturur. Olay işleyicisi, her yükseltildiğinde özelliğin ElapsedEventArgs.SignalTime değerini görüntüler.

using System;
using System.Timers;

public class Example
{
    private static Timer aTimer;

    public static void Main()
    {
        // Create a timer and set a two second interval.
        aTimer = new System.Timers.Timer();
        aTimer.Interval = 2000;

        // Hook up the Elapsed event for the timer. 
        aTimer.Elapsed += OnTimedEvent;

        // Have the timer fire repeated events (true is the default)
        aTimer.AutoReset = true;

        // Start the timer
        aTimer.Enabled = true;

        Console.WriteLine("Press the Enter key to exit the program at any time... ");
        Console.ReadLine();
    }

    private static void OnTimedEvent(Object source, System.Timers.ElapsedEventArgs e)
    {
        Console.WriteLine("The Elapsed event was raised at {0}", e.SignalTime);
    }
}
// The example displays output like the following: 
//       Press the Enter key to exit the program at any time... 
//       The Elapsed event was raised at 5/20/2015 8:48:58 PM 
//       The Elapsed event was raised at 5/20/2015 8:49:00 PM 
//       The Elapsed event was raised at 5/20/2015 8:49:02 PM 
//       The Elapsed event was raised at 5/20/2015 8:49:04 PM 
//       The Elapsed event was raised at 5/20/2015 8:49:06 PM

Açıklamalar

true ayarı Enabled çağrısıyla Startaynıdır, olarak ayar Enabledfalse ise çağrısıyla Stopaynıdır.

Not

Olayı tetiklemeye yönelik Elapsed sinyal her zaman bir ThreadPool iş parçacığında yürütülmek üzere kuyruğa alınır. Bu, özelliği olarak ayarlandıktan falsesonra olayın tetiklenmesine Enabled neden Elapsed olabilir. Yöntemin Stop kod örneği, bu yarış koşuluna geçici bir çözüm gösterir.

olarak ayarlanırsa ve olarak ayarlanırsa EnabledTimerfalse, aralık ilk kez geçtiğinde olayı yalnızca bir kez tetiklerElapsed.AutoResettrue

başlatıldıktan sonra Timer aralık ayarlanırsa, sayı sıfırlanır. Örneğin, aralığı 5 saniye olarak ayarlarsanız ve ardından özelliğini olarak trueayarlarsanızEnabled, sayı o anda Enabled başlar. Sayım 3 saniye olduğunda aralığı 10 saniyeye sıfırlarsanız, Elapsed olay olarak ayarlandıktan true13 saniye sonra Enabled ilk kez oluşturulur.

Not

Microsoft Visual Studio'dakiler gibi bazı görsel tasarımcılar, yeni Timerbir eklerken özelliğini olarak true ayarlarEnabled.

Şunlara uygulanır

Ürün Sürümler
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1

Ayrıca bkz.