我们有一个WPF应用程序,其中:
private void SomeHandler(object sender, RoutedEventArgs e)
{
Task.Factory.StartNew(LoadItems).ContinueWith(t =>
{
//cache items to, for instance, db
}, TaskContinuationOptions.NotOnFaulted);
}
private void LoadItems()
{
//sometimes it throws an exception
//this is expected
throw new FormatException("blablabla");
}
因此,通常,我们使用此处理程序尝试在数据存在时缓存数据。 如果它不存在那么我们得到一个Formatexception。我们不关心结果,只关注“火与忘”策略。
我最近从客户端获得了两个日志文件,在那里我看到FormatException传播到CurrentDomain_UnhandledException处理程序。所有客户端都在Windows XP上使用.Net 4.0。
所以问题是为什么会这样?它是按设计的吗?
答案 0 :(得分:2)
这是.Net 4.0上的预期行为。如果有一个带有异常的Task
并且从未观察到该异常,那么在Task
完成时会重新抛出异常。
如果您安装了.Net 4.5并且希望获得此行为(例如用于测试),add <ThrowUnobservedTaskExceptions>
to app.config。
如果您想确保不会重新抛出未观察到的Task
例外,即使在.Net 4.0上,您也可以使用TaskScheduler.UnobservedTaskException
:
TaskScheduler.UnobservedTaskException += (o, args) => args.SetObserved();
但我认为这里最好的选择是明确地观察异常。您可以通过删除NotOnFaulted
选项并检查Exception
属性来执行此操作:
Task.Factory.StartNew(LoadItems).ContinueWith(t =>
{
if (t.Exception == null)
{
//cache items to, for instance, db
}
});