Task.Run()会对性能产生任何影响吗?

时间:2013-08-04 00:56:42

标签: c# asp.net-mvc-4 task-parallel-library async-await c#-5.0

我有一个调用数据库的方法,如下所示:

BL方法调用DAO方法:

    public async Task<List<Classes>> GetClassesAndAddRules(string classId)
    {
        var classData = await Task.Run( () => _daoClass.GetClasses(classId));

        //logic for adding rule
        //..................................
    }

DAO中的DatabaseCall:

   //*below method takes 1 second approx to return*
    public List<Classes> GetClasses(string id)
    {
        var retVal = new List<Classes>();

        using (var context = new test_db_context())
        {
            var rows = context.GetClassesById(id);
            foreach (ClassesDBComplexType row in rows)
            {
                retVal.Add(Mapper.Map<GetClassesByClassIdOut>(row));
            }
        }
        return retVal;
    }

使用等待调用DAO方法是否有任何性能提升?

我的理解是GetClasses()将在一个单独的线程上调用,这样它就不会阻塞并继续处理其他东西。

感谢任何帮助。

1 个答案:

答案 0 :(得分:5)

您发布的代码无法编译。从您问题的标题来看,我假设您的通话实际上看起来像await Task.Run(() => _daoClass.GetClasses(classId));

在这种情况下,使用Task.Run 会对性能产生影响:情况会更糟。

服务器端的async点是释放请求线程而不是阻止它。你使用await Task.Run(...)做的是通过开始另一个线程的工作来释放请求线程。换句话说,Task.Run代码与 plus 线程编组具有相同的工作量。