微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我想在单独的线程中处理长时间运行的操作,并使用async / await模式将控制返回到GUI线程,如下所示:
private async void Button_Click(object sender,RoutedEventArgs e)
{
    await test();
    txtResult.Text = "Done!";
}

private Task test()
{
    Thread.Sleep(3000);
    return Task.Fromresult(0);
}

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

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

private void Button_Click(object sender,RoutedEventArgs e)
{
    var thread = new Thread(() => Test(Callback));
    thread.Start();
}

private void Callback()
{
    dispatcher.Invoke(() =>
        txtResult.Text = "Done!");
}

private void Test(Action callback)
{
    Thread.Sleep(3000); //long running operation,not necessarily pause
    callback();
}

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

解决方法

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

原文地址:https://www.jb51.cc/csharp/92045.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐