我有一个调用数据库的方法,如下所示:
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()将在一个单独的线程上调用,这样它就不会阻塞并继续处理其他东西。
感谢任何帮助。
答案 0 :(得分:5)
您发布的代码无法编译。从您问题的标题来看,我假设您的通话实际上看起来像await Task.Run(() => _daoClass.GetClasses(classId));
在这种情况下,使用Task.Run
会对性能产生影响:情况会更糟。
服务器端的async
点是释放请求线程而不是阻止它。你使用await Task.Run(...)
做的是通过开始另一个线程的工作来释放请求线程。换句话说,Task.Run
代码与 plus 线程编组具有相同的工作量。