使用Task.Factory.StartNew新创建的线程启动非常缓慢

在使用Task.Factory.StartNew创建的大约50-200个短生存工作线程的WPF / c#应用程序中,在新创建的线程开始执行之前需要1到10秒。

这个非常慢的线程执行开始的原因是什么?

更新:延迟是500毫秒

发现当使用的线程池线程数超过特定值时,线程池可能不愿意每500毫秒启动多个新线程。 然而,使用ThreadPool.SetMinThreads增加MinThreads – 即使不建议 – 到100使我能够创建100个线程而没有500毫秒的延迟。

这是帮助我的原因:

编辑:

这是我在App.xaml.cs中做的结果(在构造函数中):

 // Get thread pool information int workerThreadsMin, completionPortThreadsMin; ThreadPool.GetMinThreads(out workerThreadsMin, out completionPortThreadsMin); int workerThreadsMax, completionPortThreadsMax; ThreadPool.GetMaxThreads(out workerThreadsMax, out completionPortThreadsMax); // Adjust min threads ThreadPool.SetMinThreads(workerThreadsMax, completionPortThreadsMin);