如果想學習Asp.Net2.0的非同步頁技術,那麼一定要仔細閱讀http://www.microsoft.com/china/MSDN/library/default.mspx?mfr=true ,並且下載它的源代碼仔細揣摩。全文共介紹了3種實作非同步頁的程式設計模型,且功能一種比一種強大。多餘的我就不多說了,直接看最後一種模型:使用PageAsyncTask類別、RegisterAsyncTask方法、ExecuteRegisteredAsyncTasks方法和TimeoutAsyncOperation方法註冊並執行非同步任務,並針對長時間無回應的情況呼叫逾時處理方法。原文所提供原始碼的AsyncPageTask.aspx.cs檔案詳細範例了使用這個模型實作非同步頁的方法。
這個模型最大的好處是可以在一次頁面請求中處理多個非同步任務,並且還可以用超時處理來避免在執行非同步操作時出現的無回應情況。原作者僅僅在Page_Load中註冊了一個非同步任務,那麼我們仿照他的做法,再註冊一個非同步任務,如下所示:
<%@ Page Async="true" AsyncTimeout="5" Language="C#" MasterPageFile="~/Site.master" AutoEventWireup="true" CodeFile="AsyncPageTask.aspx.cs" Inherits="AsyncPageTask" Title=" Untitled Page" %>
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
PageAsyncTask task = new PageAsyncTask(
new BeginEventHandler(BeginAsyncOperation),
new EndEventHandler(EndAsyncOperation),
new EndEventHandler(TimeoutAsyncOperation),
null
);
PageAsyncTask task1 = new PageAsyncTask(
new BeginEventHandler(BeginAsyncOperation1),
new EndEventHandler(EndAsyncOperation1),
new EndEventHandler(TimeoutAsyncOperation1),
null
);
RegisterAsyncTask(task);
RegisterAsyncTask(task1);
}
}
如果在頁面屬性AsyncTimeout的規定時間內得到非同步任務回傳的結果,那麼頁面將會依照我們預期的顯示。但是如果在執行第一個任務時遇到了小麻煩,耽誤了時間會怎麼樣呢?有兩種可能:一是,第一個任務的結果最終返回並顯示出來,而第二個任務剛一啟動就被判定為超時,從而執行了它的TimeoutAsyncOperation方法;二是,第一個任務沒有等到返回結果就已被判超時,因此第二個任務也一定被判超時了。以上情況是由於兩個非同步任務分享了AsyncTimeout規定的時間,只要前面那個任務在執行時耽誤了時間,必然影響到後面那個任務的運行。那麼能不能讓兩個非同步任務獨享AsyncTimeout所規定的時間呢,這就要在ExecuteRegisteredAsyncTasks方法上找出路了。
值得注意的是,每次呼叫ExecuteRegisteredAsyncTasks時,Asp.net2.0都會重置AsyncTimeout屬性,這意味著有可能實現非同步任務獨享AsyncTimeout規定的時間。依照目前程式的寫法,如果不顯示呼叫ExecuteRegisteredAsyncTasks方法,Asp.net2.0會在頁面生命週期中的PreRenderComplete
事件之前自動呼叫ExecuteRegisteredAsyncTasks方法來執行這兩個註冊的非同步任務。因為只執行了一次ExecuteRegisteredAsyncTasks卻執行了兩個任務,那麼這兩個任務就只好分享AsyncTimeout規定的運行時間了。於是我對程式碼做了以下調整:
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
PageAsyncTask task = new PageAsyncTask(
new BeginEventHandler(BeginAsyncOperation),
new EndEventHandler(EndAsyncOperation),
new EndEventHandler(TimeoutAsyncOperation),
null
);
PageAsyncTask task1 = new PageAsyncTask(
new BeginEventHandler(BeginAsyncOperation1),
new EndEventHandler(EndAsyncOperation1),
new EndEventHandler(TimeoutAsyncOperation1),
null
);
RegisterAsyncTask(task);
ExecuteRegisteredAsyncTasks();
RegisterAsyncTask(task1);
ExecuteRegisteredAsyncTasks();
}
}
乍看之下似乎有點問題:第二個ExecuteRegisteredAsyncTasks方法會不會將註冊的第一個非同步任務再執行一次?其實不會的,因為Asp.net2.0已經規定同一個非同步方法只會執行一次。因此這樣就使兩個非同步任務獨享了運行時間,避免了互相干擾。
http://www.cnblogs.com/taewind/archive/2006/12/22/600687.html