【发布时间】:2014-07-10 19:01:37
【问题描述】:
我正在使用 async/await 来调用一些外部 API。它们都返回一个字符串值,但格式不同,需要自己处理。 我想在任务完成时处理返回的值。我不想等到一切都完成,因此我正在使用 Task.WhenAny()。如何在任务完成时处理任务,并且在完成每个任务时仍然使用正确的“处理”方法?
我在第一次发帖后做了一些更改,这是我最新的:
public async Task<List<string>> Get()
{
var task1 = Method1Async();
var task2 = Method1Async();
var tasks = new List<Task<string>> {task1, task2};
var results = new List<string>();
while (tasks.Count > 0)
{
var justCompletedTask = await Task.WhenAny(tasks);//will not throw
tasks.Remove(justCompletedTask);
try
{
var result = await justCompletedTask;
results.Add(result);
}
catch(Exception)
{
//deal with it
}
}
return results;
}
private async Task<string> Method1Async()
{
//this may throw - something like forbidden or any other exception
var task = _httpClient.GetStringAsync("api1's url here");
var result = await Method1ResultProcessorAsync(task);
return result;
}
private async Task<string> Method1ResultProcessorAsync(Task<string> task)
{
//process task's result -if it successuflly completed and return that
return await task; //for now
}
private async Task<string> Method2Async()
{
//this may throw - something like forbidden or any other exception
var task = _httpClient.GetStringAsync("api2's url here");
var result = await Method2ResultProcessorAsync(task);
return await task;
}
private async Task<string> Method2ResultProcessorAsync(Task<string> task)
{
//This processing logic is entirely different from Method1ResultProcessor
//process task's result -if it successfully completed and return that
return await task; //for now
}
我有两个问题:
- 这是解决问题的正确方法吗?
- 这里如何更好地处理异常?这是非常重要的,所以一个人的失败不应该让整个事情失败。只要任何一种方法成功,就可以了。但是如果都失败了,我想把Get方法扔掉。
【问题讨论】:
-
显示你正在使用的代码。
-
我用代码示例更新了它
-
能否请您使用您使用的语言进行标记。我以前从未见过 :-)
-
它是 C# 5.0 的异步/等待特性。已添加标签。感谢 I3arnon 和 Klaus 提出的观点
-
看看Task.ContinueWith msdn.microsoft.com/en-us/library/dd270696(v=vs.110).aspx
标签: c# task-parallel-library async-await c#-5.0