我写了一个简单的程序来实现master / worker方案,其中master是主线程,而worker是由它创建的。
主线程向共享缓冲区写入内容,工作线程读取此共享缓冲区,通过读/写锁定来编写和读取共享缓冲区。
不幸的是,这个方案肯定会导致主线程的饥饿,因为单个写操作必须等待几个读操作才能完成。一种可能的解决方案是增加主线程的优先级,因此如果它想要写一些东西,它将立即访问共享缓冲区。
根据类似问题的great post,我发现可能不允许在SCHED_OTHER
策略下操纵线程的优先级,可以更改的只是nice
值
我编写了一个程序,使工作线程的优先级低于主线程,但似乎无法正常工作。
void assignWorkerThreadPriority(pthread_t* worker)
{
struct sched_param* worker_sched_param = (struct sched_param*)malloc(sizeof(struct sched_param));
worker_sched_param->sched_priority =0; //any value other than 0 gives error?
int policy = SCHED_OTHER;
pthread_setschedparam(*worker, policy, worker_sched_param);
printf("Result of changing priority is: %d - %s\n", errno, strerror(errno));
}
我有一个双重问题:
编辑:我设法使用其他政策运行程序,例如SCHED_FIFO
,所有我必须做的就是以超级用户身份运行程序
答案 0 :(得分:1)
当读取和写入使用情况均匀时, 无法避免使用读/写锁定的问题。你需要一个不同的方法。您需要一个无锁消息队列或独立工作队列或许多其他技术之一。
这是另一种完成工作的方式,就像我这样做的方式。工作人员可以拿走缓冲区并对其进行操作而不是保持共享:
你可以修改它。例如,工作线程可以锁定队列并将有限数量的工作项移动到其自己的内部队列中,而不是完成所有工作。