我正在使用Threading.Timer在我的應用程序中運行消息泵。替代Monitor.TryEnter在NET 3.5
有時候需要的工作需要的時間比計時器間隔的時間間隔長,我需要將代碼「跳過」。
我寫了一個小的測試程序進行測試,並保持運行到我鎖定一個SynchronizationLockException:
static void Main(string[] args)
{Program t = new Program();
System.Threading.Timer myTimer = new Timer(t.Tick,null,1000,1000);
Thread.Sleep(10000);
myTimer.Change(0,0);
Console.WriteLine("Waiting on lock in main thread...");
Monitor.Enter(t.myLock);
Console.WriteLine("Done");
Monitor.Exit(t.myLock);
}
public readonly Object myLock = new Object();
public void Tick(object state)
{
Console.WriteLine("Acquiring lock! From thread " + Thread.CurrentThread.ManagedThreadId);
Monitor.TryEnter(myLock);
try
{
Thread.Sleep(6000);
Console.WriteLine("Inside workload!From thread " + Thread.CurrentThread.ManagedThreadId);
}
finally
{
Console.WriteLine("Releasing lock!From thread " + Thread.CurrentThread.ManagedThreadId);
Monitor.Exit(myLock);
}
}
我現在不能回憶鏈接,但我已經找到了建議的解決方法我最初的要求通過在回調函數的開始和結束時禁用和啓用計時器,但由於文檔指出在計時器停止後,它仍然可以調用 ,因爲它可能已經在.NET ThreadPool上進行了調度。
我在這裏丟失了一些明顯的東西,還是顯示器不能正常工作? 我在.NET 3.5,所以
Monitor.TryEnter(myLock,hasLock)
家飯店沒有一個選項。
我前一陣子實現與此類似,您在正確的軌道與'Monitor.TryEnter' /'Monitor.Lock'上,如果你想*跳過*處理。看到我的[問題](http://stackoverflow.com/questions/1698393/using-lock-with-threading-timer)。 – James