加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 限制并发线程数等于处理器数量?

发布时间:2020-12-15 18:01:42 所属栏目:百科 来源:网络整理
导读:将执行给定任务的并发线程数限制为等于主机系统上的处理器数量有什么好处?或者更好的是简单地信任像.NET的ThreadPool这样的库来做正确的事情……即使在任何给定的时刻发生了25个不同的并发线程? 解决方法 大多数线程不受CPU限制,它们最终会等待IO或其他事
将执行给定任务的并发线程数限制为等于主机系统上的处理器数量有什么好处?或者更好的是简单地信任像.NET的ThreadPool这样的库来做正确的事情……即使在任何给定的时刻发生了25个不同的并发线程?

解决方法

大多数线程不受CPU限制,它们最终会等待IO或其他事件.如果你现在看一下你的系统,我想你有100个(如果不是1000个)线程执行没有问题.通过这个措施,你可能最好离开.NET线程池做正确的事情!

但是,如果线程都是CPU绑定的(例如光线跟踪之类的东西),那么将线程数限制为内核数量是个好主意,否则上下文切换可能会开始损害性能.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读