Asp.Net2.0中实现多任务异步页的一点提示

  如果想学习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已经规定同一个异步方法只会执行一次。因此这样就使两个异步任务独享了运行时间,避免了互相干扰。   

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值