Task底层使用的是ThreadPool,通过设置线程池线程数量来控制Task并发

public static bool SetMaxThreads (int workerThreads, int completionPortThreads);

 

Int32 workerThreads   线程池中辅助线程的最大数目。

Int32 completionPortThreads    线程池中异步 I/O 线程的最大数目。

只设置最大线程数量如果小于电脑逻辑处理器数量,总是会设置失败

只设置最大线程数量大于等于电脑逻辑处理器数量,就可以设置成功

先设置最小线程数量,然后设置最大线程数量则不受到逻辑处理器数量限制,
设置最小线程数量一定要放在设置最大线程数量之前

最大线程数最小为1,否则会设置失败,最小线程数可以为0

注解

不能将工作线程或 i/o 完成线程的最大数目设置为小于计算机上的处理器数。 若要确定有多少个处理器,请检索 Environment.ProcessorCount 属性的值。 此外,不能将最大工作线程或 i/o 完成线程的最大数目设置为小于工作线程或 i/o 完成线程对应的最小数目的数字。 若要确定最小线程池大小,请调用 GetMinThreads 方法。

如果托管公共语言运行时(例如 Internet Information Services (IIS)或 SQL Server),则宿主可能会限制或阻止对线程池大小所做的更改。

更改线程池中线程的最大数量时,请务必小心。 虽然你的代码可能会受益,但所做的更改可能会对你使用的代码库产生不利影响。

将线程池大小设置得太大可能会导致性能问题。 如果同时执行的线程太多,任务切换开销会成为一个重要因素。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值