zoukankan      html  css  js  c++  java
  • ASP.NET MVC什么时候使用异步Action

    在没有使用异步Action之前,在Action内,比如有如下的写法:

    public ActionResult Index()
    
        CustomerHelper cHelper = new CustomerHelper();
    
    Customer> result = cHelper.GetCustomerData();
    
        return View(result);
    
    }

    以上,假设,GetCustomerData方法是调用第三方的服务,整个过程都是同步的,大致是:

    →请求来到Index这个Action
    →ASP.NET从线程池中抓取一个线程
    →执行GetCustomerData方法调用第三方服务,假设持续8秒钟的时间,执行完毕
    →渲染Index视图

    在执行执行GetCustomerData方法的时候,由于是同步的,这时候无法再从线程池抓取其它线程,只能等到GetCustomerData方法执行完毕。

    这时候,可以改善一下整个过程。

    →请求来到Index这个Action
    →ASP.NET从线程池中抓取一个线程服务于Index这个Action方法
    →同时,ASP.NET又从线程池中抓取一个线程服务于GetCustomerData方法
    →渲染Index视图,同时获取GetCustomerData方法返回的数据

    所以,当涉及到多种请求,比如,一方面是来自客户的请求,一方面需要请求第三方的服务或API,可以考虑使用异步Action。

    假设有这样的一个View Model:

    public class Customer
    
        public int Id{get;set;}
    
        public Name{get;set;}
    
    }

    假设使用Entity Framework作为ORM框架。

    public class CustomerHelper
    
    	public async Task<List<Customer>> GetCustomerDataAsync()
    
    		MyContenxt db = new MyContext();
    
    					orderby c.Id ascending
    
    					select c;
    
    Customer>	result = awai query.ToListAsycn();
    
    		return result;				
    
    }

    现在就可以写一个异步Action了。

    public async Task<ActionResult> Index()
    
    	CustomerHelper cHelper = new CustomerHelper();
    
    Customer> result = await cHlper.GetCustomerDataAsync();
    
    	return View(result);
    
    }

    Index视图和同步的时候相比,并没有什么区别。

    @model List<Customer>
    
    {
    
    span>@customer.Name</span>
    
    }

    当然,异步还设计到一个操作超时,默认的是45秒,但可以通过AsyncTimeout特性来设置。

    [AsyncTimeout(3000)]
    
    ActionResult> Index()
    
    	...
    
    }

    如果不想对操作超时设限。

    [NoAsyncTimeout]
    
    ActionResult> Index()
    
    	...
    
    }

    综上,当涉及到调用第三方服务的时候,就可以考虑使用异步Action。async和await是异步编程的2个关键字,async总和Action成对出现,而在调用异步方法之前要加上await关键字。

  • 相关阅读:
    Python正课38 —— 有参装饰器
    Python正课37 —— 无参装饰器
    Python正课36 —— 闭包函数
    Python正课35 —— 函数对象与函数嵌套
    Python正课34 —— Global与Nonlocal
    Python正课33 —— 名称空间 与 作用域 介绍
    vue中wowjs的使用
    js得到时间戳(10位数)
    腾讯地图使用中,出现了“鉴权失败,请传入正确的key”
    js数组操作大全
  • 原文地址:https://www.cnblogs.com/hnsongbiao/p/8798876.html
Copyright © 2011-2022 走看看