TPL异常处理

时间:2011-10-25 21:56:08

标签: c#-4.0

http://msdn.microsoft.com/en-us/library/dd997415.aspx

根据上面引用的文章,我试图处理continuatin任务中的异常。我在上面的文章中引用的例子是:

var task1 = Task.Factory.StartNew(() =>
{
    throw new MyCustomException("Task1 faulted.");
})
.ContinueWith((t) =>
    {
        Console.WriteLine("I have observed a {0}",
            t.Exception.InnerException.GetType().Name);
    },
    TaskContinuationOptions.OnlyOnFaulted);

我的代码是:

Task<string> task = Task<string>.Factory.StartNew(() => process.StartTask(this));
task.ContinueWith(CloseDialog, TaskContinuationOptions.OnlyOnFaulted);

在StartTask中,我像示例一样抛出错误。我的期望是CloseDialog将执行,我可以检查该方法中的task.Exception,如示例所示。但是,当我抛出异常时,代码只会因未处理的异常而停止。我应该使用try / catch块吗?如果是的话,在哪里? 顺便说一句,我希望我的延续任务(CloseDialog)始终运行。我只是使用.OnlyOnFaulted,因为这是示例中显示的内容。

1 个答案:

答案 0 :(得分:11)

延续可以查明先行任务的异常属性是否由前提Task抛出异常。以下内容将NullReferenceException的结果打印到控制台

Task task1 = Task.Factory.StartNew (() => { throw null; });
Task task2 = task1.ContinueWith (ant => Console.Write(ant.Exception());

如果task1抛出异常并且延迟未捕获/查询此异常,则认为未处理并且应用程序死亡。通过延续,只需通过Status关键字

建立任务结果即可
asyncTask.ContinueWith(task =>
{
    // Check task status.
    switch (task.Status)
    {
        // Handle any exceptions to prevent UnobservedTaskException.             
        case TaskStatus.RanToCompletion:
            if (asyncTask.Result)
            {
                // Do stuff...
            }
            break;
        case TaskStatus.Faulted:
            if (task.Exception != null)
                mainForm.progressRightLabelText = task.Exception.InnerException.Message;
            else
                mainForm.progressRightLabelText = "Operation failed!";
        default:
            break;
    }
}

如果您不使用延续,则必须等待try / catch块中的任务或查询Result / {中的任务try {1}}阻止

catch

希望这有帮助,即使它有点晚了,你现在已经知道了! :