确保每个线程都有机会使用C 11线程在给定时间段内执行

假设我在C 11中有一个多线程程序,其中每个线程控制向用户显示的内容的行为.

我想确保在给定程序的一个线程运行的每个时间段T内,每个线程都有机会执行至少时间t,以便显示看起来好像所有线程同时执行.我们的想法是根据存储在线程中的一些信息,使用时间共享进行循环调度,强制线程在其时间片结束后等待,而不是依赖于操作系统调度程序.

最好,我还想确保每个线程都是实时安排的.

如果除了依赖操作系统之外别无他法,Linux有什么解决方案吗?

是否有可能做到这一点?怎么样?

解决方法:

I want to ensure that for every time period T during which one of the threads of the given program have run, each thread gets a chance to execute for at least time t, so that the display looks as if all threads are executing simultaneously.

您正在使用线程使其看起来好像同时执行不同的任务.由于亚瑟答案中所述的原因,我不推荐这样做,我真的无法添加任何内容.

如果不是让每个生命线程都执行自己的任务,而是可以拥有一个可以在不相互排斥的情况下执行的任务队列 – 您可以拥有一个任务队列和一个线程池队列和执行任务.

如果你不能,你可能想要研究等待免费的数据结构和算法.在无等待的算法/数据结构中,保证每个线程以有限(甚至指定)的步数完成其工作.我可以推荐“多处理器编程的艺术”一书,其中详细讨论了这个主题.它的要点是:每个无锁算法/数据结构都可以通过在线程之间添加通信来修改为等待*,在这些线程上即将运行的线程确保没有其他线程被饿死/停止.基本上,更喜欢所有线程的总吞吐量的公平性.根据我的经验,这通常不是一个很好的妥协.

上一篇:Linux中的热感知调度程序


下一篇:Linux使用哪种进程调度算法?