1、同步和异步的区别
当未使用异步页时,一个线程只能为同一个页面的请求服务. 即使页面请求过程中处理其它的I/O等操作时,此线程也一直处于等待状态. 当此页面使用完此线程时,才将它放回到线程池. 线程数量是有限的! 所以当不使用线程时及时放回线池可以使系统性能大大提高!
当使用了异步页功能时,如右图中,开始Thread1是为页面服务的,但当页面处理其它的事情(比如I/O或调用其它WebService) 时,Thread1被放回线程池, 此时Thread1可以为其它页面请求服务了. 当此页面执行完自己的操作回来后, Thread2接着为页面请求服务,并不是使用的原来的线程Thread1. 这样网站的伸缩性会更好.
2、使用示例
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
public partial class _Default : System.Web.UI.Page
{ const string RSSFEED = "http://weblogs.asp.net/scottgu/rss.aspx";
private WebRequest req;
public string rssResult;
public int tick;
protected void Page_Load(object sender, EventArgs e)
{
int started = System.Environment.TickCount;
AddOnPreRenderCompleteAsync(
new BeginEventHandler(BeginTask),
new EndEventHandler(EndTask));
tick = System.Environment.TickCount - started;
//PageAsyncTask task = new PageAsyncTask(
// new BeginEventHandler(BeginTask),
// new EndEventHandler(EndTask),
// new EndEventHandler(TimeOut),
// null);
//RegisterAsyncTask(task);
}
IAsyncResult BeginTask(object sender, EventArgs e, AsyncCallback cb, object state)
{
Trace.Warn("Begin asyc: Thread=" + Thread.CurrentThread.ManagedThreadId.ToString());
req = WebRequest.Create(RSSFEED);
return req.BeginGetResponse(cb, state);
}
void EndTask(IAsyncResult ar)
{
using (WebResponse response = req.EndGetResponse(ar))
{
StreamReader reader;
using (reader = new StreamReader(response.GetResponseStream()))
{
rssResult = reader.ReadToEnd();
}
}
Trace.Warn("End async: Thread=" + Thread.CurrentThread.ManagedThreadId.ToString());
}
void TimeOut(IAsyncResult ar)
{
Response.Write("Time Out");
Response.End();
}
}
|
前台页面
本文转自敏捷的水博客园博客,原文链接http://www.cnblogs.com/cnblogsfans/archive/2009/11/05/1596619.html如需转载请自行联系原作者
王德水