c# – 使用async await仍会冻结GUI

前端之家收集整理的这篇文章主要介绍了c# – 使用async await仍会冻结GUI前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想在单独的线程中处理长时间运行的操作,并使用async / await模式将控制返回到GUI线程,如下所示:
  1. private async void Button_Click(object sender,RoutedEventArgs e)
  2. {
  3. await Test();
  4. txtResult.Text = "Done!";
  5. }
  6.  
  7. private Task Test()
  8. {
  9. Thread.Sleep(3000);
  10. return Task.FromResult(0);
  11. }

问题是,它无论如何都会冻结GUI 3秒钟(在3秒后显示Done!之前它会变得无法响应).我究竟做错了什么?

编辑:
我想替换以下逻辑:

  1. private void Button_Click(object sender,RoutedEventArgs e)
  2. {
  3. var thread = new Thread(() => Test(Callback));
  4. thread.Start();
  5. }
  6.  
  7. private void Callback()
  8. {
  9. Dispatcher.Invoke(() =>
  10. txtResult.Text = "Done!");
  11. }
  12.  
  13. private void Test(Action callback)
  14. {
  15. Thread.Sleep(3000); //long running operation,not necessarily pause
  16. callback();
  17. }

在实际项目中,我有不同的长时间运行逻辑而不仅仅是Sleep,它仍然会冻结GUI,因此用Task.Delay替换它并不能解决任何问题.此外,我不明白为什么你应该使用另一个命令睡眠? async / await设计需要什么?

解决方法

您可以使用Task.Run或Task.Factory.StartNew在另一个线程上执行Test()或一些长时间运行和/或阻塞操作:
  1. private async void Button_Click(object sender,RoutedEventArgs e)
  2. {
  3. await Task.Run(() => Test());
  4. txtResult.Text = "Done!";
  5. }

猜你在找的C#相关文章