Timer Oluşturucular
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Timer
sınıfının yeni bir örneğini başlatır.
Aşırı Yüklemeler
Timer(TimerCallback) |
Yeni oluşturulan Timer nesneyi durum nesnesi olarak kullanarak, sınıfın Timer yeni bir örneğini sonsuz bir süre ve sonsuz bir süreyle başlatır. |
Timer(TimerCallback, Object, Int32, Int32) |
Zaman aralığını belirtmek için 32 bit imzalı bir tamsayı kullanarak sınıfının yeni bir örneğini |
Timer(TimerCallback, Object, Int64, Int64) |
Zaman aralıklarını ölçmek için 64 bit imzalı tamsayılar kullanarak sınıfının yeni bir örneğini |
Timer(TimerCallback, Object, TimeSpan, TimeSpan) |
Zaman aralıklarını ölçmek için değerleri kullanarak TimeSpan sınıfının yeni bir örneğini |
Timer(TimerCallback, Object, UInt32, UInt32) |
Zaman aralıklarını ölçmek için 32 bit işaretsiz tamsayılar kullanarak sınıfının yeni bir örneğini |
Timer(TimerCallback)
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
public:
Timer(System::Threading::TimerCallback ^ callback);
public Timer (System.Threading.TimerCallback callback);
new System.Threading.Timer : System.Threading.TimerCallback -> System.Threading.Timer
Public Sub New (callback As TimerCallback)
Parametreler
- callback
- TimerCallback
TimerCallback Yürütülecek yöntemi temsil eden bir temsilci.
Örnekler
Aşağıdaki kod örneği, durum nesnesi olarak zamanlayıcının kendisini kullanarak yeni bir zamanlayıcı oluşturur. Change yöntemi zamanlayıcıyı başlatmak için kullanılır. Zamanlayıcı geri çağırması gerçekleştiğinde, zamanlayıcıyı kapatmak için durum nesnesi kullanılır.
using System;
using System.Threading;
public class Example
{
public static void Main()
{
// Create an instance of the Example class, and start two
// timers.
Example ex = new Example();
ex.StartTimer(2000);
ex.StartTimer(1000);
Console.WriteLine("Press Enter to end the program.");
Console.ReadLine();
}
public void StartTimer(int dueTime)
{
Timer t = new Timer(new TimerCallback(TimerProc));
t.Change(dueTime, 0);
}
private void TimerProc(object state)
{
// The state object is the Timer object.
Timer t = (Timer) state;
t.Dispose();
Console.WriteLine("The timer callback executes.");
}
}
Imports System.Threading
Public Class Example
Public Shared Sub Main()
' Create an instance of the Example class, and start two
' timers.
Dim ex As New Example()
ex.StartTimer(2000)
ex.StartTimer(1000)
Console.WriteLine("Press Enter to end the program.")
Console.ReadLine()
End Sub
Public Sub StartTimer(ByVal dueTime As Integer)
Dim t As New Timer(AddressOf TimerProc)
t.Change(dueTime, 0)
End Sub
Private Sub TimerProc(ByVal state As Object)
' The state object is the Timer object.
Dim t As Timer = CType(state, Timer)
t.Dispose()
Console.WriteLine("The timer callback executes.")
End Sub
End Class
Açıklamalar
Nesnenin Timer kendisini durum nesnesi olarak kullanmak istediğinizde bu oluşturucuyu çağırın. Zamanlayıcıyı oluşturduktan sonra, aralığı ve son zamanı ayarlamak için yöntemini kullanın Change .
Bu oluşturucu, ilk geri çağırmadan önce sonsuz bir süre ve nesne durum nesnesine atanmadan önce Timer ilk geri çağırmanın gerçekleşmesini önlemek için geri çağırmalar arasında sonsuz bir zaman aralığı belirtir.
için callback
belirtilen yöntem, iş parçacıklarında ThreadPool çağrıldığından yeniden oturum açması gerekir. Zamanlayıcı aralığı yöntemi yürütmek için gereken süreden azsa veya tüm iş parçacığı havuzu iş parçacıkları kullanımdaysa ve yöntem birden çok kez kuyruğa alınmışsa, yöntem aynı anda iki iş parçacığı havuzu iş parçacığında yürütülebilir.
Şunlara uygulanır
Timer(TimerCallback, Object, Int32, Int32)
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
Zaman aralığını belirtmek için 32 bit imzalı bir tamsayı kullanarak sınıfının yeni bir örneğini Timer
başlatır.
public:
Timer(System::Threading::TimerCallback ^ callback, System::Object ^ state, int dueTime, int period);
public Timer (System.Threading.TimerCallback callback, object state, int dueTime, int period);
public Timer (System.Threading.TimerCallback callback, object? state, int dueTime, int period);
new System.Threading.Timer : System.Threading.TimerCallback * obj * int * int -> System.Threading.Timer
Public Sub New (callback As TimerCallback, state As Object, dueTime As Integer, period As Integer)
Parametreler
- callback
- TimerCallback
TimerCallback Yürütülecek yöntemi temsil eden bir temsilci.
- state
- Object
Veya geri çağırma yöntemi null
tarafından kullanılacak bilgileri içeren bir nesne.
- dueTime
- Int32
Milisaniye cinsinden çağrılmadan önce callback
gecikme süresi. Zamanlayıcının başlatılmasını önlemek için belirtin Infinite . Zamanlayıcıyı hemen başlatmak için sıfır (0) belirtin.
- period
- Int32
çağrısı arasındaki callback
milisaniye cinsinden zaman aralığı. Düzenli sinyallerin devre dışı bırakılacağını belirtin Infinite .
Özel durumlar
dueTime
veya period
parametresi negatiftir ve değerine Infiniteeşit değildir.
callback
parametresidirnull
.
Örnekler
Aşağıdaki kod örneği, bir TimerCallback
temsilci oluşturma ve sınıfın yeni bir örneğini başlatma işlemini Timer
gösterir.
using namespace System;
using namespace System::Threading;
ref class StatusChecker
{
private:
int invokeCount, maxCount;
public:
StatusChecker(int count)
{
invokeCount = 0;
maxCount = count;
}
// This method is called by the timer delegate.
void CheckStatus(Object^ stateInfo)
{
AutoResetEvent^ autoEvent = dynamic_cast<AutoResetEvent^>(stateInfo);
Console::WriteLine("{0:h:mm:ss.fff} Checking status {1,2}.",
DateTime::Now, ++invokeCount);
if (invokeCount == maxCount) {
// Reset the counter and signal the waiting thread.
invokeCount = 0;
autoEvent->Set();
}
}
};
ref class TimerExample
{
public:
static void Main()
{
// Create an AutoResetEvent to signal the timeout threshold in the
// timer callback has been reached.
AutoResetEvent^ autoEvent = gcnew AutoResetEvent(false);
StatusChecker^ statusChecker = gcnew StatusChecker(10);
// Create a delegate that invokes methods for the timer.
TimerCallback^ tcb =
gcnew TimerCallback(statusChecker, &StatusChecker::CheckStatus);
// 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);
Timer^ stateTimer = gcnew Timer(tcb, autoEvent, 1000, 250);
// When autoEvent signals, change the period to every half second.
autoEvent->WaitOne(5000, false);
stateTimer->Change(0, 500);
Console::WriteLine("\nChanging period to .5 seconds.\n");
// When autoEvent signals the second time, dispose of the timer.
autoEvent->WaitOne(5000, false);
stateTimer->~Timer();
Console::WriteLine("\nDestroying timer.");
}
};
int main()
{
TimerExample::Main();
}
// 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.
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.
Açıklamalar
parametresi tarafından belirtilen temsilci, geçtikten callback
sonra dueTime
bir kez ve ardından zaman aralığı her geçtiğinde period
çağrılır.
Sıfır ise dueTime
(0), callback
hemen çağrılır. ise dueTime
Timeout.Infinitecallback
çağrılmıyorsa; zamanlayıcı devre dışıdır, ancak yöntemi çağrılarak Change yeniden etkinleştirilebilir.
Sınıfı, Timer Windows 7 ve Windows 8 sistemlerinde yaklaşık 15 milisaniye olan sistem saatiyle aynı çözünürlüğe sahip olduğundan, callback
temsilci sistem saatinin çözünürlüğünden küçükse period
sistem saatinin çözünürlüğüyle tanımlanan aralıklarla yürütülür. sıfır (0) ise period
veya dueTime
Timeout.Infinite değilse Timeout.Infinitebir callback
kez çağrılır; zamanlayıcının düzenli davranışı devre dışı bırakılır, ancak yöntemi kullanılarak Change yeniden etkinleştirilebilir.
Not
Kullanılan sistem saati, TimeBeginPeriod ve timeEndPeriod ile yapılan değişikliklerden etkilenmeyen GetTickCount tarafından kullanılan saatle aynıdır.
için callback
belirtilen yöntem, iş parçacıklarında ThreadPool çağrıldığından yeniden oturum açması gerekir. Zamanlayıcı aralığı yöntemi yürütmek için gereken süreden azsa veya tüm iş parçacığı havuzu iş parçacıkları kullanımdaysa ve yöntem birden çok kez kuyruğa alınmışsa, yöntem aynı anda iki iş parçacığı havuzu iş parçacığında yürütülebilir.
Ayrıca bkz.
Şunlara uygulanır
Timer(TimerCallback, Object, Int64, Int64)
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
Zaman aralıklarını ölçmek için 64 bit imzalı tamsayılar kullanarak sınıfının yeni bir örneğini Timer
başlatır.
public:
Timer(System::Threading::TimerCallback ^ callback, System::Object ^ state, long dueTime, long period);
public Timer (System.Threading.TimerCallback callback, object? state, long dueTime, long period);
public Timer (System.Threading.TimerCallback callback, object state, long dueTime, long period);
new System.Threading.Timer : System.Threading.TimerCallback * obj * int64 * int64 -> System.Threading.Timer
Public Sub New (callback As TimerCallback, state As Object, dueTime As Long, period As Long)
Parametreler
- callback
- TimerCallback
TimerCallback Yürütülecek yöntemi temsil eden bir temsilci.
- state
- Object
Veya geri çağırma yöntemi null
tarafından kullanılacak bilgileri içeren bir nesne.
- dueTime
- Int64
Milisaniye cinsinden çağrılmadan önce callback
gecikme süresi. Zamanlayıcının başlatılmasını önlemek için belirtin Infinite . Zamanlayıcıyı hemen başlatmak için sıfır (0) belirtin.
- period
- Int64
çağrısı arasındaki callback
milisaniye cinsinden zaman aralığı. Düzenli sinyallerin devre dışı bırakılacağını belirtin Infinite .
Özel durumlar
dueTime
veya period
parametresi negatiftir ve değerine Infiniteeşit değildir.
dueTime
veya period
parametresi 4294967294 büyüktür.
Açıklamalar
parametresi tarafından belirtilen temsilci, geçtikten callback
sonra dueTime
bir kez ve ardından zaman aralığı her geçtiğinde period
çağrılır.
Sıfır ise dueTime
(0), callback
hemen çağrılır. ise dueTime
Timeout.Infinitecallback
çağrılmıyorsa; zamanlayıcı devre dışıdır, ancak yöntemi çağrılarak Change yeniden etkinleştirilebilir.
Sınıfı, Timer Windows 7 ve Windows 8 sistemlerinde yaklaşık 15 milisaniye olan sistem saatiyle aynı çözünürlüğe sahip olduğundan, callback
temsilci sistem saatinin çözünürlüğünden küçükse period
sistem saatinin çözünürlüğüyle tanımlanan aralıklarla yürütülür. sıfır (0) ise period
veya dueTime
Timeout.Infinite değilse Timeout.Infinitebir callback
kez çağrılır; zamanlayıcının düzenli davranışı devre dışı bırakılır, ancak yöntemi kullanılarak Change yeniden etkinleştirilebilir.
Not
Kullanılan sistem saati, TimeBeginPeriod ve timeEndPeriod ile yapılan değişikliklerden etkilenmeyen GetTickCount tarafından kullanılan saatle aynıdır.
için callback
belirtilen yöntem, iş parçacıklarında ThreadPool çağrıldığından yeniden oturum açması gerekir. Zamanlayıcı aralığı yöntemi yürütmek için gereken süreden azsa veya tüm iş parçacığı havuzu iş parçacıkları kullanımdaysa ve yöntem birden çok kez kuyruğa alınmışsa, yöntem aynı anda iki iş parçacığı havuzu iş parçacığında yürütülebilir.
Ayrıca bkz.
Şunlara uygulanır
Timer(TimerCallback, Object, TimeSpan, TimeSpan)
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
Zaman aralıklarını ölçmek için değerleri kullanarak TimeSpan sınıfının yeni bir örneğini Timer
başlatır.
public:
Timer(System::Threading::TimerCallback ^ callback, System::Object ^ state, TimeSpan dueTime, TimeSpan period);
public Timer (System.Threading.TimerCallback callback, object state, TimeSpan dueTime, TimeSpan period);
public Timer (System.Threading.TimerCallback callback, object? state, TimeSpan dueTime, TimeSpan period);
new System.Threading.Timer : System.Threading.TimerCallback * obj * TimeSpan * TimeSpan -> System.Threading.Timer
Public Sub New (callback As TimerCallback, state As Object, dueTime As TimeSpan, period As TimeSpan)
Parametreler
- callback
- TimerCallback
Yürütülecek yöntemi temsil eden bir temsilci.
- state
- Object
Veya geri çağırma yöntemi null
tarafından kullanılacak bilgileri içeren bir nesne.
- dueTime
- TimeSpan
çağrılmadan önce callback
geciktirme süresi. Zamanlayıcının başlatılmasını önlemek için belirtin InfiniteTimeSpan . Zamanlayıcıyı hemen başlatmak için belirtin Zero .
- period
- TimeSpan
çağrısı callback
arasındaki zaman aralığı. Düzenli sinyallerin devre dışı bırakılacağını belirtin InfiniteTimeSpan .
Özel durumlar
veya period
değerindeki dueTime
milisaniye sayısı negatiftir ve değerine eşit Infinitedeğildir veya Int32.MaxValue değerinden büyüktür.
callback
parametresidirnull
.
Örnekler
Aşağıdaki kod örneği, bir TimerCallback
temsilci oluşturma ve sınıfın yeni bir örneğini başlatma işlemini Timer
gösterir.
using namespace System;
using namespace System::Threading;
ref class StatusChecker
{
private:
int invokeCount;
int maxCount;
public:
StatusChecker( int count )
: invokeCount( 0 ), maxCount( count )
{}
// This method is called by the timer delegate.
void CheckStatus( Object^ stateInfo )
{
AutoResetEvent^ autoEvent = dynamic_cast<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 main.
invokeCount = 0;
autoEvent->Set();
}
}
};
int main()
{
AutoResetEvent^ autoEvent = gcnew AutoResetEvent( false );
StatusChecker^ statusChecker = gcnew StatusChecker( 10 );
// Create the delegate that invokes methods for the timer.
TimerCallback^ timerDelegate = gcnew TimerCallback( statusChecker, &StatusChecker::CheckStatus );
TimeSpan delayTime = TimeSpan(0,0,1);
TimeSpan intervalTime = TimeSpan(0,0,0,0,250);
// Create a timer that signals the delegate to invoke CheckStatus
// after one second, and every 1/4 second thereafter.
Console::WriteLine( "{0} Creating timer.\n", DateTime::Now.ToString( "h:mm:ss.fff" ) );
Timer^ stateTimer = gcnew Timer( timerDelegate,autoEvent,delayTime,intervalTime );
// When autoEvent signals, change the period to every 1/2 second.
autoEvent->WaitOne( 5000, false );
stateTimer->Change( TimeSpan(0), intervalTime + intervalTime );
Console::WriteLine( "\nChanging period.\n" );
// When autoEvent signals the second time, dispose of the timer.
autoEvent->WaitOne( 5000, false );
stateTimer->~Timer();
Console::WriteLine( "\nDestroying timer." );
}
using System;
using System.Threading;
class TimerExample
{
static void Main()
{
AutoResetEvent autoEvent = new AutoResetEvent(false);
StatusChecker statusChecker = new StatusChecker(10);
// Create the delegate that invokes methods for the timer.
TimerCallback timerDelegate =
new TimerCallback(statusChecker.CheckStatus);
TimeSpan delayTime = new TimeSpan(0, 0, 1);
TimeSpan intervalTime = new TimeSpan(0, 0, 0, 0, 250);
// Create a timer that signals the delegate to invoke
// CheckStatus after one second, and every 1/4 second
// thereafter.
Console.WriteLine("{0} Creating timer.\n",
DateTime.Now.ToString("h:mm:ss.fff"));
Timer stateTimer = new Timer(
timerDelegate, autoEvent, delayTime, intervalTime);
// When autoEvent signals, change the period to every
// 1/2 second.
autoEvent.WaitOne(5000, false);
stateTimer.Change(new TimeSpan(0),
intervalTime + intervalTime);
Console.WriteLine("\nChanging period.\n");
// When autoEvent signals the second time, dispose of
// the timer.
autoEvent.WaitOne(5000, false);
stateTimer.Dispose();
Console.WriteLine("\nDestroying timer.");
}
}
class StatusChecker
{
int invokeCount, 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 Main.
invokeCount = 0;
autoEvent.Set();
}
}
}
Imports System.Threading
Public Class TimerExample
<MTAThread> _
Shared Sub Main()
Dim autoEvent As New AutoResetEvent(False)
Dim statusChecker As New StatusChecker(10)
' Create the delegate that invokes methods for the timer.
Dim timerDelegate As TimerCallback = _
AddressOf statusChecker.CheckStatus
Dim delayTime As New TimeSpan(0, 0, 1)
Dim intervalTime As New TimeSpan(0, 0, 0, 0, 250)
' Create a timer that signals the delegate to invoke
' CheckStatus after one second, and every 1/4 second
' thereafter.
Console.WriteLine("{0} Creating timer." & vbCrLf, _
DateTime.Now.ToString("h:mm:ss.fff"))
Dim stateTimer As Timer = New Timer( _
timerDelegate, autoEvent, delayTime, intervalTime)
' When autoEvent signals, change the period to every
' 1/2 second.
autoEvent.WaitOne(5000, False)
stateTimer.Change( _
new TimeSpan(0), intervalTime.Add(intervalTime))
Console.WriteLine(vbCrLf & "Changing period." & vbCrLf)
' When autoEvent signals the second time, dispose of
' the timer.
autoEvent.WaitOne(5000, False)
stateTimer.Dispose()
Console.WriteLine(vbCrLf & "Destroying timer.")
End Sub
End Class
Public Class StatusChecker
Dim invokeCount, maxCount As Integer
Sub New(count As Integer)
invokeCount = 0
maxCount = count
End Sub
' This method is called by the timer delegate.
Sub CheckStatus(stateInfo As Object)
Dim autoEvent As AutoResetEvent = _
DirectCast(stateInfo, AutoResetEvent)
invokeCount += 1
Console.WriteLine("{0} Checking status {1,2}.", _
DateTime.Now.ToString("h:mm:ss.fff"), _
invokeCount.ToString())
If invokeCount = maxCount Then
' Reset the counter and signal to stop the timer.
invokeCount = 0
autoEvent.Set()
End If
End Sub
End Class
Açıklamalar
parametresi tarafından belirtilen temsilci, geçtikten callback
sonra dueTime
bir kez ve ardından zaman aralığı her geçtiğinde period
çağrılır.
Sıfır ise dueTime
(0), callback
hemen çağrılır. Negatif bir (-1) milisaniye ise dueTime
çağrılmıyorsa callback
, zamanlayıcı devre dışı bırakılır, ancak yöntemi çağrılarak Change yeniden etkinleştirilebilir.
Sınıfı, Timer Windows 7 ve Windows 8 sistemlerinde yaklaşık 15 milisaniye olan sistem saatiyle aynı çözünürlüğe sahip olduğundan, callback
temsilci sistem saatinin çözünürlüğünden küçükse period
sistem saatinin çözünürlüğüyle tanımlanan aralıklarla yürütülür. Sıfır (0) veya negatif bir (-1) milisaniye ise period
ve dueTime
pozitifse, callback
bir kez çağrılır; zamanlayıcının düzenli davranışı devre dışı bırakılır, ancak yöntemi kullanılarak Change yeniden etkinleştirilebilir.
Not
Kullanılan sistem saati, TimeBeginPeriod ve timeEndPeriod ile yapılan değişikliklerden etkilenmeyen GetTickCount tarafından kullanılan saatle aynıdır.
için callback
belirtilen yöntem, iş parçacıklarında ThreadPool çağrıldığından yeniden oturum açması gerekir. Zamanlayıcı aralığı yöntemi yürütmek için gereken süreden azsa veya tüm iş parçacığı havuzu iş parçacıkları kullanımdaysa ve yöntem birden çok kez kuyruğa alınmışsa, yöntem aynı anda iki iş parçacığı havuzu iş parçacığında yürütülebilir.
Ayrıca bkz.
Şunlara uygulanır
Timer(TimerCallback, Object, UInt32, UInt32)
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
- Kaynak:
- Timer.cs
Önemli
Bu API, CLS uyumlu değildir.
Zaman aralıklarını ölçmek için 32 bit işaretsiz tamsayılar kullanarak sınıfının yeni bir örneğini Timer
başlatır.
public:
Timer(System::Threading::TimerCallback ^ callback, System::Object ^ state, System::UInt32 dueTime, System::UInt32 period);
[System.CLSCompliant(false)]
public Timer (System.Threading.TimerCallback callback, object? state, uint dueTime, uint period);
[System.CLSCompliant(false)]
public Timer (System.Threading.TimerCallback callback, object state, uint dueTime, uint period);
[<System.CLSCompliant(false)>]
new System.Threading.Timer : System.Threading.TimerCallback * obj * uint32 * uint32 -> System.Threading.Timer
Public Sub New (callback As TimerCallback, state As Object, dueTime As UInteger, period As UInteger)
Parametreler
- callback
- TimerCallback
Yürütülecek yöntemi temsil eden bir temsilci.
- state
- Object
Veya geri çağırma yöntemi null
tarafından kullanılacak bilgileri içeren bir nesne.
- dueTime
- UInt32
Milisaniye cinsinden çağrılmadan önce callback
gecikme süresi. Zamanlayıcının başlatılmasını önlemek için belirtin Infinite . Zamanlayıcıyı hemen başlatmak için sıfır (0) belirtin.
- period
- UInt32
çağrısı arasındaki callback
milisaniye cinsinden zaman aralığı. Düzenli sinyallerin devre dışı bırakılacağını belirtin Infinite .
- Öznitelikler
Özel durumlar
dueTime
veya period
parametresi negatiftir ve değerine Infiniteeşit değildir.
callback
parametresidirnull
.
Açıklamalar
parametresi tarafından belirtilen temsilci, geçtikten callback
sonra dueTime
bir kez ve ardından zaman aralığı her geçtiğinde period
çağrılır.
Sıfır ise dueTime
(0), callback
hemen çağrılır. ise dueTime
Timeout.Infinitecallback
çağrılmıyorsa; zamanlayıcı devre dışıdır, ancak yöntemi çağrılarak Change yeniden etkinleştirilebilir.
Timer sınıfı, Windows 7 ve Windows 8 sistemlerinde yaklaşık 15 milisaniye olan sistem saatiyle aynı çözünürlüğe sahip olduğundan, callback
temsilci sistem saatinin çözünürlüğünden küçükse period
sistem saatinin çözünürlüğüyle tanımlanan aralıklarla yürütülür. Sıfır (0) ise period
veya Timeout.InfinitedueTime
değilse Timeout.Infinite, callback
bir kez çağrılır; zamanlayıcının düzenli davranışı devre dışı bırakılır, ancak yöntemi kullanılarak Change yeniden etkinleştirilebilir.
Not
Kullanılan sistem saati GetTickCount tarafından kullanılan saatle aynıdır ve timeBeginPeriod ve timeEndPeriod ile yapılan değişikliklerden etkilenmez.
İş parçacıklarında ThreadPool çağrıldığından, için callback
belirtilen yöntemin yeniden oturum açması gerekir. Zamanlayıcı aralığı yöntemi yürütmek için gereken süreden azsa veya tüm iş parçacığı havuzu iş parçacıkları kullanımdaysa ve yöntem birden çok kez kuyruğa alınmışsa, yöntem iki iş parçacığı havuzu iş parçacığında aynı anda yürütülebilir.