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()的所有诱惑.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...