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

c# – BackgroundWorkers从不停止忙

for (do it a bunch of times)
{         
    while (backgroundWorker1.IsBusy && backgroundWorker2.IsBusy &&
           backgroundWorker3.IsBusy && backgroundWorker4.IsBusy &&
           backgroundWorker5.IsBusy)
    {
        System.Threading.Thread.Sleep(0001);
    }

    if (!backgroundWorker1.IsBusy)
    {
        backgroundWorker1.RunWorkerAsync();
    }
    else if (!backgroundWorker2.IsBusy)
    {
        backgroundWorker2.RunWorkerAsync();
    }
    else if (!backgroundWorker3.IsBusy)
    {
        backgroundWorker3.RunWorkerAsync();
    }
    else if (!backgroundWorker4.IsBusy)
    {
        backgroundWorker4.RunWorkerAsync();
    }
    else if (!backgroundWorker5.IsBusy)
    {
        backgroundWorker5.RunWorkerAsync();
    }
}

它运行了五次(每个BG工人一次),并被困住了.背景工作者不要停止忙吗?如何查看可用性?

注意:有5个工作线程,这确保他们中没有一个被阻止,总是给他们分配工作.但他们拒绝告诉我什么时候可以使用,我以为会有一个简单的解决方

– [编辑请求] —

其实这只是一个虚拟参数,我删除它,忘了把它弄出来,我只用它来调用dowork,谁做肮脏的工作:

private void backgroundWorker1_DoWork(object sender,DoWorkEventArgs e)
{
    timeconsumingfunction(publicstring);
}

时间功能功能结束.在调试器中逐步进入并运行行,直到结束并到达最终的’}’.这意味着它结束了,对吧?

— [编辑回答] —-
它由JUST替代该线

System.Threading.Thread.Sleep(0001);

Application.DoEvents();

我想它会运行的背景,但没有收到答案,而不是更新IsBusy标签.

感谢大家,伟大的答案,帮助很多!

解决方法

您的循环造成死锁,BGW无法完成.问题是RunWorkerCompleted事件,它是在UI线程上引发的.这个BGW魔法要求UI线程空闲,它必须抽取其消息循环.问题是,UI线程不是空闲的,它没有抽取消息,它被卡在for循环中.因此,事件处理程序无法运行,IsBusy保持为真.

你需要这样做.利用RunWorkerCompleted事件来运行通常在此for循环之后运行的代码.抵制在循环内调用Application.DoEvents()的所有诱惑.

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

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

相关推荐