c# – 使用Task.Factory.StartNew新创建的线程启动速度非常慢
发布时间:2020-12-15 07:56:59 所属栏目:百科 来源:网络整理
导读:在使用Task.Factory.StartNew创建的大约50-200个短生存工作线程的 WPF / c#应用程序中,在新创建的线程开始执行之前需要1到10秒. 这个非常慢的线程执行开始的原因是什么? 更新: 延迟是500毫秒 解决方法 发现当使用的线程池线程数超过特定值时,线程池可能不
在使用Task.Factory.StartNew创建的大约50-200个短生存工作线程的
WPF / c#应用程序中,在新创建的线程开始执行之前需要1到10秒.
这个非常慢的线程执行开始的原因是什么? 更新: 解决方法
发现当使用的线程池线程数超过特定值时,线程池可能不愿意每500毫秒启动多个新线程.然而,使用
ThreadPool.SetMinThreads增加MinThreads – 即使不推荐 – 到100使我能够创建100个线程而没有500毫秒延迟.
这是帮助我的原因: > http://alexpinsker.blogspot.com/2009/06/threadpool.html 编辑: 这是我在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); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |