正如标题中已经指出的,我有大量线程(可能远远高于100个线程),它们保存程序状态而不是运行。我只希望它们中的几个(足够使用所有物理处理器)真正并行运行,其余的应该等待直到其中一个运行被阻塞。当这种情况发生时,一个新的应该正在运行。
是否有可能通过p线程来实现这一点,例如,使用p线程调度函数?你会怎么做?
致以敬意,
没有人
编辑更多信息:每个线程自己从任务池中获取一个作业,然后继续到某个特定的点。我需要100个线程收集在程序执行的特定点,不能并行计算。当计算完成后,线程应该被唤醒并继续进行。为了提高效率,我必须避免调度程序将时间浪费在100个线程之间而不是4个线程之间。
发布于 2011-07-11 16:40:15
发布于 2011-07-11 16:34:09
您可以每次启动4,将它们分配给线程组,然后在线程组上使用join all等待。但我认为需要更多的信息,才能找到一个真正有用的答案。
发布于 2011-07-11 18:49:38
将全局变量初始化为运行concurrently.
的特定线程库调用的https://computing.llnl.gov/tutorials/pthreads/#Mutexes。
https://stackoverflow.com/questions/6653237
复制相似问题