ASP.net MVC4 AsyncController异步action无法异步执行?


最新需要用到mvc4 的异步action,以实现页面ajax同时指定一个耗时查询。

使用了AsyncController。

参考文章:

http://www.oschina.net/question/565065_68409


public class DevController : AsyncController
{


        public Task<ActionResult> Article2(string name)
        {
            return Task.Factory.StartNew(() =>
            {
                string path = ControllerContext.HttpContext.Server.MapPath(string.Format(@"\articles\{0}.html", name));
                using (StreamReader reader = new StreamReader(path))
                {
                    return reader.ReadToEnd();
                }
            }).ContinueWith<ActionResult>(task =>
            {
                return Content((string)task.Result);
            });
        }
}



执行起来没有问题,但是实际中使用发现,几个ajax调用虽是同时发起请求,但是服务器段还是同步依次执行每个action。。。。


原来需要增加如下内容:

    [SessionState(SessionStateBehavior.ReadOnly)]
<pre name="code" class="csharp">public class DevController : AsyncController
{
 
。。。。。。。
}




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用.NET的List异步循环时,我们可以通过async和await关键字来实现在执行完成后再执行后面的代码。异步循环通常用于处理耗时较长的操作,以避免阻塞主线程,提高程序的性能和响应速度。 首先,我们需要在方法的声明中使用async关键字来标识该方法为异步方法。然后,在使用foreach循环遍历List的时候,我们可以使用await关键字来暂停当前的执行,等待异步操作完成。 例如,假设我们有一个List<int> numbers,我们想对其中的每个元素进行异步处理,然后再执行后面的代码。代码示例如下: ```csharp async Task SomeMethod() { List<int> numbers = new List<int> { 1, 2, 3, 4, 5 }; foreach(var number in numbers) { await SomeAsyncOperation(number); // 异步处理 // 执行完成后的代码 Console.WriteLine($"处理完成:{number}"); } // 所有异步操作完成后的代码 Console.WriteLine("所有异步操作已完成"); } async Task SomeAsyncOperation(int number) { // 模拟异步操作 await Task.Delay(1000); Console.WriteLine($"正在处理:{number}"); } ``` 在上述代码中,我们定义了一个SomeMethod方法,其中使用了async关键字来表示该方法为异步方法。在循环遍历List的过程中,我们使用了await关键字来暂停执行,并等待SomeAsyncOperation方法的异步操作完成。 在SomeAsyncOperation方法中,我们使用Task.Delay来模拟一个耗时操作,并输出当前处理的数字。在实际的应用中,你可以替换为实际的异步操作。 当所有的异步操作都完成后,程序会继续执行之后的代码,输出"所有异步操作已完成"。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值