使用Task.Factory.StartNew新创建的线程启动非常缓慢
在使用Task.Factory.StartNew
创建的大约50-200个短生存工作线程的WPF / c#应用程序中,在新创建的线程开始执行之前需要1到10秒。
这个非常慢的线程执行开始的原因是什么?
更新:延迟是500毫秒
发现当使用的线程池线程数超过特定值时,线程池可能不愿意每500毫秒启动多个新线程。 然而,使用ThreadPool.SetMinThreads增加MinThreads – 即使不建议 – 到100使我能够创建100个线程而没有500毫秒的延迟。
这是帮助我的原因:
-
http://msdn.microsoft.com/en-us/library/system.threading.threadpool.setminthreads%28v=vs.100%29.aspx
编辑:
这是我在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);