利用Timer在ASP.NET中實現(xiàn)計劃任務(wù)的方法
更新時間:2007年04月13日 00:00:00 作者:
.NET Framework中為我們提供了3種類型的Timer,分別是:
Server Timer(System.Timers.Timer),Thread Timer(System.Threading.Timer )和Windows Timer(System.Windows.Forms.Timer)。
其中Windows Timer和WinAPI中的Timer一樣,是基于消息的,而且是單線程的。另外兩個Timer則不同于Windows Timer,它們是基于ThreadPool的,這樣最大的好處就是,產(chǎn)生的時間間隔準(zhǔn)確均勻。Server Timer和Thread Timer的區(qū)別在于,Server Timer是基于事件的,而Thread Timer是基于Callback的。
相比之下Thread Timer更輕量級一些,所以下文主要以Thread Timer為例,講解如何利用Thread Timer在ASP.NET中實現(xiàn)計劃任務(wù)。
下面給出一個用Timer實現(xiàn)計劃任務(wù)的類:
public class ScheduledTask
{
private static readonly ScheduledTask _ScheduledTask = null;
private Timer UpdateTimer = null;
//間隔時間,這里設(shè)置為15分鐘
private int Interval = 15 * 60000;
private int _IsRunning;
static ScheduledTask()
{
_ScheduledTask = new ScheduledTask();
}
public static ScheduledTask Instance()
{
return _ScheduledTask;
}
public void Start()
{
if(UpdateTimer == null)
{
UpdateTimer = new Timer(new TimerCallback(UpdateTimerCallback), null, Interval, Interval);
}
}
private void UpdateTimerCallback(object sender)
{
if(Interlocked.Exchange(ref _IsRunning, 1) == 0)
{
try
{
//此處寫你自己想執(zhí)行的任務(wù)
}
catch(Exception ex)
{
}
finally
{
Interlocked.Exchange(ref _IsRunning, 0);
}
}
}
public void Stop()
{
if(UpdateTimer != null)
{
UpdateTimer.Dispose();
UpdateTimer = null;
}
}
}
首先,注意一下這段:private int _IsRunning;
_IsRunning是一個標(biāo)志,它代表上一個時間間隔觸發(fā)的任務(wù)是否運行完成。
為什么我們需要這個_IsRunning標(biāo)志呢?
因為,如果我們執(zhí)行的任務(wù)時間很長,就可能造成上一個時間段觸發(fā)的任務(wù)還沒有執(zhí)行完成,下一個任務(wù)又開始了,這樣就會造成重入的問題。為了解決這個問題,我們用_IsRunning作為一個標(biāo)志,表示上次的任務(wù)是否完成了,如果完成了,我們就執(zhí)行新的任務(wù),如果沒完成就跳過這次的任務(wù)繼續(xù)執(zhí)行上次的任務(wù)。
具體的邏輯在下面這段代碼中實現(xiàn):
程序代碼
private void UpdateTimerCallback(object sender)
{
if(Interlocked.Exchange(ref _IsRunning, 1) == 0)
{
try
{
//此處寫你自己想執(zhí)行的任務(wù)
}
catch(Exception ex)
{
}
finally
{
Interlocked.Exchange(ref _IsRunning, 0);
}
}
}
大家看到,上面代碼中用到了Interlocked.Exchange這個方法。該方法的作用是保證多線程下給對象賦值的安全性。因為在多線程下,我們直接給_IsRunning賦值是不安全的,所以在這種情況下Interlocked.Exchange就派上了用場。
說完了ScheduledTask類的實現(xiàn),下面我們看看如何在ASP.NET中調(diào)用這個類。
建議在Application_Start中調(diào)用這個類,代碼如下:
程序代碼
public class Global : System.Web.HttpApplication
{
protected void Application_Start(object sender, EventArgs e)
{
ScheduledTask.Instance().Start();
}
protected void Application_End(object sender, EventArgs e)
{
ScheduledTask.Instance().Stop();
}
}
OK,以上就是Timer在ASP.NET中的簡單應(yīng)用,如果有什么說的不對的地方,還請多多指教。
Server Timer(System.Timers.Timer),Thread Timer(System.Threading.Timer )和Windows Timer(System.Windows.Forms.Timer)。
其中Windows Timer和WinAPI中的Timer一樣,是基于消息的,而且是單線程的。另外兩個Timer則不同于Windows Timer,它們是基于ThreadPool的,這樣最大的好處就是,產(chǎn)生的時間間隔準(zhǔn)確均勻。Server Timer和Thread Timer的區(qū)別在于,Server Timer是基于事件的,而Thread Timer是基于Callback的。
相比之下Thread Timer更輕量級一些,所以下文主要以Thread Timer為例,講解如何利用Thread Timer在ASP.NET中實現(xiàn)計劃任務(wù)。
下面給出一個用Timer實現(xiàn)計劃任務(wù)的類:
public class ScheduledTask
{
private static readonly ScheduledTask _ScheduledTask = null;
private Timer UpdateTimer = null;
//間隔時間,這里設(shè)置為15分鐘
private int Interval = 15 * 60000;
private int _IsRunning;
static ScheduledTask()
{
_ScheduledTask = new ScheduledTask();
}
public static ScheduledTask Instance()
{
return _ScheduledTask;
}
public void Start()
{
if(UpdateTimer == null)
{
UpdateTimer = new Timer(new TimerCallback(UpdateTimerCallback), null, Interval, Interval);
}
}
private void UpdateTimerCallback(object sender)
{
if(Interlocked.Exchange(ref _IsRunning, 1) == 0)
{
try
{
//此處寫你自己想執(zhí)行的任務(wù)
}
catch(Exception ex)
{
}
finally
{
Interlocked.Exchange(ref _IsRunning, 0);
}
}
}
public void Stop()
{
if(UpdateTimer != null)
{
UpdateTimer.Dispose();
UpdateTimer = null;
}
}
}
首先,注意一下這段:private int _IsRunning;
_IsRunning是一個標(biāo)志,它代表上一個時間間隔觸發(fā)的任務(wù)是否運行完成。
為什么我們需要這個_IsRunning標(biāo)志呢?
因為,如果我們執(zhí)行的任務(wù)時間很長,就可能造成上一個時間段觸發(fā)的任務(wù)還沒有執(zhí)行完成,下一個任務(wù)又開始了,這樣就會造成重入的問題。為了解決這個問題,我們用_IsRunning作為一個標(biāo)志,表示上次的任務(wù)是否完成了,如果完成了,我們就執(zhí)行新的任務(wù),如果沒完成就跳過這次的任務(wù)繼續(xù)執(zhí)行上次的任務(wù)。
具體的邏輯在下面這段代碼中實現(xiàn):
程序代碼
private void UpdateTimerCallback(object sender)
{
if(Interlocked.Exchange(ref _IsRunning, 1) == 0)
{
try
{
//此處寫你自己想執(zhí)行的任務(wù)
}
catch(Exception ex)
{
}
finally
{
Interlocked.Exchange(ref _IsRunning, 0);
}
}
}
大家看到,上面代碼中用到了Interlocked.Exchange這個方法。該方法的作用是保證多線程下給對象賦值的安全性。因為在多線程下,我們直接給_IsRunning賦值是不安全的,所以在這種情況下Interlocked.Exchange就派上了用場。
說完了ScheduledTask類的實現(xiàn),下面我們看看如何在ASP.NET中調(diào)用這個類。
建議在Application_Start中調(diào)用這個類,代碼如下:
程序代碼
public class Global : System.Web.HttpApplication
{
protected void Application_Start(object sender, EventArgs e)
{
ScheduledTask.Instance().Start();
}
protected void Application_End(object sender, EventArgs e)
{
ScheduledTask.Instance().Stop();
}
}
OK,以上就是Timer在ASP.NET中的簡單應(yīng)用,如果有什么說的不對的地方,還請多多指教。
您可能感興趣的文章:
- Asp.Net(C#)自動執(zhí)行計劃任務(wù)的程序?qū)嵗治龇窒?/a>
- asp.net 在客戶端顯示服務(wù)器端任務(wù)處理進度條的探討
- asp.net 定時間點執(zhí)行任務(wù)的簡易解決辦法
- asp.net 每天定點執(zhí)行任務(wù)
- asp.net 計劃任務(wù)管理程序?qū)崿F(xiàn),多線程任務(wù)加載
- C#(asp.net)多線程用法示例(可用于同時處理多個任務(wù))
- ASP.NET 計劃任務(wù)實現(xiàn)方法(不使用外接程序,.net內(nèi)部機制實現(xiàn))
- 詳解免費開源的DotNet任務(wù)調(diào)度組件Quartz.NET(.NET組件介紹之五)
- Asp.net ajax實現(xiàn)任務(wù)提示頁面的簡單代碼
- .NET Core基于Generic Host實現(xiàn)后臺任務(wù)方法教程
相關(guān)文章
基于ASP.NET+easyUI框架實現(xiàn)圖片上傳功能(表單)
這篇文章主要介紹了基于ASP.NET+easyUI框架實現(xiàn)圖片上傳功能的相關(guān)資料,需要的朋友可以參考下2016-06-06
asp.net html控件的File控件實現(xiàn)多文件上傳實例分享
asp.net中html控件的File控件實現(xiàn)多文件上傳簡單實例,開發(fā)工具vs2010使用c#語言,感興趣的朋友可以了解下,必定是多文件上傳值得學(xué)習(xí),或許本文所提供的知識點對你有所幫助2013-02-02
ASP.NET實現(xiàn)頁面?zhèn)髦档膸追N方法小結(jié)
這篇文章介紹了ASP.NET實現(xiàn)頁面?zhèn)髦档膸追N方法,有需要的朋友可以參考一下2013-11-11
國產(chǎn)化之銀河麒麟安裝.netcore3.1的詳細步驟(手動安裝)
這篇文章主要介紹了國產(chǎn)化之銀河麒麟安裝.netcore3.1的詳細步驟(手動安裝),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
ASP.NET MVC SSO單點登錄設(shè)計與實現(xiàn)代碼
本篇文章主要介紹了ASP.NET MVC SSO單點登錄設(shè)計與實現(xiàn),具有一定的參考價值,有興趣的可以了解一下。2017-01-01

