我的视图<Button Content="Search" cal:Message.Attach="SearchAsync"/>
中有一个按钮,该按钮调用一个函数,从而引发异常。我正在尝试使用
protected override void OnUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e)
{
e.Handled = true;
e.Exception.Log();
}
public async Task SearchAsync()
,则错误只会被吞没,并且永远不会达到OnUnhandledException,public async void SearchAsync()
会引发异常,但调试器将停止并等待我在void函数中按继续,并且我需要为每个Task函数创建一个void函数,并且SearchCommand = new AsyncReactiveCommand().WithSubscribe(async () => await SearchAsync());
)。据我所知,应该将异步void用于操作,因为它们是事件处理程序(source)。
我想出的解决方案是:使用Command或将Task函数包装在try / catch中,我都不满意。
在Caliburn.Micro中使用异步和等待并仍使用cal:Message.Attach =“ xyz”语法的正确方法是什么?
优选地,我想不使用其他任何东西而使用异步任务语法,因为它提供了最佳的测试能力并且需要最少的代码。
答案 0 :(得分:0)
在Caliburn.Micro中使用异步和等待并仍使用cal:Message.Attach =“ xyz”语法的正确方法是什么?
您应该在xyz
中捕获异常:
public async Task xyz()
{
try
{
//...
}
catch (Exception ex)
{
//handle...
}
}
如果要在引导程序的OnUnhandledException
中全局处理它,则应将返回类型从Task
更改为void
。返回Task
的方法被视为协程。