c# – 捕获异步操作中的异常

我正在阅读更多关于异步在这里http://msdn.microsoft.com/en-us/library/hh873173(v=vs.110).aspx

通过这个例子:

Task<bool> [] recommendations = …;
while(recommendations.Count > 0)
{ 
    Task<bool> recommendation = await Task.WhenAny(recommendations);    
    try
    {
        if (await recommendation) BuyStock(symbol);
        break;
    }
    catch(WebException exc)
    {
        recommendations.Remove(recommendation);
    }
}

我想知道,如果我已经在等待Task.WhenAny为什么我需要等待再次尝试块?

如果我已经这样做:任务< bool>推荐=等待任务.
为什么这样做:如果(等待推荐)BuyStock(符号);

解决方法

一个等待存在异步等待第一个任务完成(即推荐).
第二个等待仅在于从已经完成的任务中提取实际结果,并抛出存储在任务中的异常. (重要的是要记住,等待完成的任务被优化并将同步执行).

获取结果的另一种选择将是使用Task< T> .Result,但是它在处理异常的方式上是不同的.等待将抛出实际异常(例如WebException),而Task< T> .Result将抛出一个包含实际异常的AggregateException.

Task<bool> [] recommendations = …;
while(recommendations.Count > 0)
{ 
    Task<bool> recommendation = await Task.WhenAny(recommendations);    
    try
    {
        if (recommendation.Result) 
        {
            BuyStock(symbol);
        }
        break;
    }
    catch(AggregateException exc)
    {
        exc = exc.Flatten();
        if (exc.InnerExceptions[0] is WebException)
        {
            recommendations.Remove(recommendation);
        }
        else
        {
            throw;
        }
    }
}

显然,等待任务更简单,所以它是从任务中检索结果的推荐方法.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...