[英]What happens to the resources when you block on a asynchronous wrapper for a synchronous method?
[英]What happens when you await a synchronous method
如果我有一个同步方法“GetStrings()”:
private static Task<string[]> GetStrings(IEnumerable<int> ids)
{
var tasks = ids.Distinct().Select(GetString);
return Task.WhenAll(tasks);
}
private static async Task<string> GetString(int stringId)
{
await Task.Delay(15000);
return "hello" + stringId;
}
(它本身称为异步方法“GetString()”)
我从异步方法中调用这个同步 “GetStrings()”方法:
public static async Task Main()
{
var ids = new List<int> { 1, 2, 3 };
await GetStrings(ids);
Console.WriteLine("all done");
Console.ReadLine();
}
如果GetStrings(
)实际上是异步的,那么行为差异会是什么? (并在Task.WhenAll
上进行了等待)
它会简单地阻止Task.WhenAll
阻止线程吗? 我找到了一些看起来像这样的生产代码,所以我把这个小例子放在一起试着去了解发生了什么。 但是很难确定差异。
Task.WhenAll
不会阻塞,与Task.WaitAll
不同。 它只返回在所有原始任务完成时完成的任务。
重要的是要理解你没有等待一个方法 - 等待一个值 (或某种必须等待的类型)。 await机制并不关心你是如何获得该值的。
如果GetStrings
是异步的,则会有一个重要的区别:抛出的任何异常(例如,如果ids
为null)将导致出现故障,而当前异常将直接抛出。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.