首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >调度大量线程,因此只有4个并行执行。

调度大量线程,因此只有4个并行执行。
EN

Stack Overflow用户
提问于 2011-07-11 16:21:50
回答 4查看 182关注 0票数 0

正如标题中已经指出的,我有大量线程(可能远远高于100个线程),它们保存程序状态而不是运行。我只希望它们中的几个(足够使用所有物理处理器)真正并行运行,其余的应该等待直到其中一个运行被阻塞。当这种情况发生时,一个新的应该正在运行。

是否有可能通过p线程来实现这一点,例如,使用p线程调度函数?你会怎么做?

致以敬意,

没有人

编辑更多信息:每个线程自己从任务池中获取一个作业,然后继续到某个特定的点。我需要100个线程收集在程序执行的特定点,不能并行计算。当计算完成后,线程应该被唤醒并继续进行。为了提高效率,我必须避免调度程序将时间浪费在100个线程之间而不是4个线程之间。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2011-07-11 16:40:15

票数 2
EN

Stack Overflow用户

发布于 2011-07-11 16:34:09

您可以每次启动4,将它们分配给线程组,然后在线程组上使用join all等待。但我认为需要更多的信息,才能找到一个真正有用的答案。

票数 0
EN

Stack Overflow用户

发布于 2011-07-11 18:49:38

将全局变量初始化为运行concurrently.

  • When的线程数--一个线程想要做的工作--它获得一个插槽。使用互斥和条件变量,它等待直到slots_available > 1,然后减少slots_available释放互斥并继续工作。当线程完成工作时,

  • 通过锁定互斥锁和递增slots_available来释放槽。它向等待条件变量的所有线程发出信号,以便它们能够唤醒并查看是否slots_available >1。

  • 查看用于上述.

的特定线程库调用的https://computing.llnl.gov/tutorials/pthreads/#Mutexes

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6653237

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档