Task中的异常处理

本文介绍了在Task并行编程中处理异常的重要性和多种方法。包括使用Wait、WaitAny、WaitAll或Result属性捕获AggregateException,通过新起后续任务避免阻塞,以及利用事件通知模型在主线程中处理异常。文章建议在处理Task中的异常时,优先考虑采用事件通知的方式,以减少对主线程的影响。
摘要由CSDN通过智能技术生成

建议85:Task中的异常处理

在任何时候,异常处理都是非常重要的一个环节。多线程与并行编程中尤其是这样。如果不处理这些后台任务中的异常,应用程序将会莫名其妙的退出。处理那些不是主线程(如果是窗体程序,那就是UI主线程)产生的异常,最终的办法都是将其包装到主线程上。

在任务并行库中,如果对任务运行Wait、WaitAny、WaitAll等方法,或者求Result属性,都能捕获到AggregateException异常。可以将AggregateException异常看做是任务并行库编程中最上层的异常。在任务中捕获的异常,最终都应该包装到AggregateException中。一个任务并行库异常的简单处理示例如下:

static void Main(string[] args)  
{  
    Task t = new Task(() =>
        {  
            throw new Exception("任务并行编码中产生的未知异常");  
        });  
    t.Start();  
 
    try  
    {  
        //若有Result,可求Result  
        t.Wait();  
    }  
    catch (AggregateException e)  
    {  
        foreach (var item in e.InnerExceptions)  
        {  
            Console.WriteLine("异常类型:{0}{1}来自:{2}{3}异常内容:{4}", item.GetType(), Environment.NewLine,  
 item.Source, Environment.NewLine, item.Message);  
        }  
    }  
    Console.WriteLine("主线程马上结束");  
    Console.ReadKey();  
}

上面的代码输出:
异常类型:System.Exception
来自:ConsoleApplication3
异常内容:任务并行编码中产生的未知异常
主线程马上结束

大家也许已经注意到,虽然运行Wait、WaitAny、WaitAll方法,或者求Result属性能得到任务的异常信息,但是这会阻滞当前线程。这往往不是我们所希望看到的,岂能为了得到一个异常就故意等待?这时可

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值