以下是生成异步方法的正确方法,其中方法中的代码必须执行多个需要等待的异步调用。
计划是启动此方法的多个,并在代码继续之前等待它们全部完成。
public static Task<string> Get(string url)
{
return Task.Run(async () =>
{
var client = getBaseHttpClient();
var result = await client.GetAsync(url).ConfigureAwait(false);
if (result.IsSuccessStatusCode)
{
return await result.Content.ReadAsStringAsync();
}
return null;
});
}
最佳答案
您的代码:
启动线程池线程(Task.Run
),
它将启动异步I/O操作(GetAsync
),然后返回线程池。
当I/O完成(await
)时,将启动另一个线程池线程(ConfigureAwait(false)
),
它将启动另一个异步I/O操作来读取HTTP响应(GetAsStringAsync
)的内容,并返回到线程池。
当I/O完成(await
)时,将启动另一个线程池线程以将内容返回到调用方法。
你可以跳过第一步。总之。它所做的只是将对getBaseHttpClient
的调用推迟到一个线程池线程,我假设这不是密集的cpu绑定工作—在这种情况下,它可以/应该同步完成。
public static async Task<string> Get(string url)
{
var client = getBaseHttpClient();
var result = await client.GetAsync(url).ConfigureAwait(false);
if (result.IsSuccessStatusCode)
{
return await result.Content.ReadAsStringAsync();
}
return null;
}
调用代码为:
var tasks = urls.Select(Get);
var responses = await Task.WhenAll(tasks);