c# – 使用Task.Factory.StartNew新创建的线程启动速度非常慢

前端之家收集整理的这篇文章主要介绍了c# – 使用Task.Factory.StartNew新创建的线程启动速度非常慢前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在使用Task.Factory.StartNew创建的大约50-200个短生存工作线程的 WPF / c#应用程序中,在新创建的线程开始执行之前需要1到10秒.

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

更新:
延迟是500毫秒

解决方法

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

这是帮助我的原因:

> http://alexpinsker.blogspot.com/2009/06/threadpool.html
> http://msdn.microsoft.com/en-us/library/system.threading.threadpool.setminthreads%28v=vs.100%29.aspx
> https://stackoverflow.com/a/13186389/600559

编辑:

这是我在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);

猜你在找的C#相关文章