我有一个方法:
var taskCount = Task<List<Client>>.Factory.StartNew(() =>
{
return ClientRepository.GetListAll();
}).LogExceptions<Client>();
count = taskCount.Result;
我将扩展方法作为 LogException 作为:
public static Task<T> LogExceptions<T>(this Task<T> task) where T : new()
{
return task.ContinueWith<T>((antecedent) =>
{
bool isError = false;
var aggException = antecedent.Exception.Flatten();
foreach (var exception in aggException.InnerExceptions)
{
isError = true;
LogWrite.LogStep(" Task Exception - ", exception.Message);
}
if (isError)
{
return new T();
}
else
{
return antecedent.Result;
}
},
TaskContinuationOptions.OnlyOnFaulted);
}
如果发生任何异常,上面的代码可以正常工作,它会处理异常并防止工作进程将其关闭。
但是当没有错误时,它只是返回聚合异常作为“任务被取消”。不确定我在上面的代码中做错了什么。
如果上面的代码是错误的,那么在任务中以通用方式处理异常的最佳方式是什么。
最佳答案
问题是您的 TaskContinuationOptions
在延续中选择了 OnlyOnFaulted
。每MSDN , OnlyOnFaulted
表示只有在前面的任务抛出未处理的异常时才会继续。由于您在所有情况下都没有遇到异常,因此延续无法正常工作。尝试省略 TaskContinuationOptions
参数或使用默认枚举值 None
。
关于c# - 任务并行库异常句柄 "A task was canceled.",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20635536/