.NET Thread Pool - Unresponsive WinForms UI

前端 未结 5 878
说谎
说谎 2021-01-22 07:48

Scenario

I have a Windows Forms Application. Inside the main form there is a loop that iterates around 3000 times, Creating a new instance of a class on a new thread to

相关标签:
5条回答
  • 2021-01-22 08:28

    If every thread logs something to your ui, every written log line must invoke the main thread. Better to cache the log-output and update the gui only every 100 iterations or something like that.

    0 讨论(0)
  • 2021-01-22 08:32

    If you are creating 3000 separate threads, you are pushing a documented limitation of the ThreadPool class:

    If an application is subject to bursts of activity in which large numbers of thread pool tasks are queued, use the SetMinThreads method to increase the minimum number of idle threads. Otherwise, the built-in delay in creating new idle threads could cause a bottleneck.

    See that MSDN topic for suggestions to configure the thread pool for your situation.

    If your work is CPU intensive, having that many separate threads will cause more overhead than it's worth. However, if it's very IO intensive, having a large number of threads may help things somewhat.

    .NET 4 introduces outstanding support for parallel programming. If that is an option for you, I suggest you have a look at that.

    0 讨论(0)
  • 2021-01-22 08:32

    It's difficult to tell without seeing code - but, based on what you're describing, there is one suspect.

    You mentioned that you have this running on the ThreadPool now. Switching to a BackgroundWorker won't change anything, dramatically, since it also uses the ThreadPool to execute. (BackgroundWorker just simplifies the invoke calls...)

    That being said, I suspect the problem is your notifications back to the UI thread for your ListBox. If you're invoking too frequently, your UI may become unresponsive while it tries to "catch up". This can happen if you're feeding too much status info back to the UI thread via Control.Invoke.

    Otherwise, make sure that ALL of your work is being done on the ThreadPool, and you're not blocking on the UI thread, and it should work.

    0 讨论(0)
  • 2021-01-22 08:38

    More threads does not equal top speed. In fact too many threads equals less speed. If your task is simply CPU related you should only be using as many threads as you have cores otherwise you're wasting resources.

    With 3,000 iterations and your form thread attempting to create a thread each time what's probably happening is you are maxing out the thread pool and the form is hanging because it needs to wait for a prior thread to complete before it can allocate a new one.

    Apparently ThreadPool doesn't work this way. I have never checked it with threads before so I am not sure. Another possibility is that the tasks begin flooding the UI thread with invocations at which point it will give up on the GUI.

    0 讨论(0)
  • 2021-01-22 08:49

    Since I haven't seen your code so this is just a lot of conjecture with some highly hopefully educated guessing.

    All a threadpool does is queue up your requests and then fire new threads off as others complete their work. Now 3000 threads doesn't sounds like a lot but if there's a ton of processing going on you could be destroying your CPU.

    I'm not convinced a background worker would help out since you will end up re-creating a manager to handle all the pooling the threadpool gives you. I think more you issue is you've got too much data chunking going on. I think a good place to start would be to throttle the amount of threads you start and maintain. The threadpool manager easily allows you to do this. Find a balance that allows you to process data while still keeping the UI responsive.

    0 讨论(0)
提交回复
热议问题