我写了一个简单的程序来实现 master/worker 方案,其中 master 是主线程,worker 是由它创建的。
主线程向共享缓冲区写入内容,工作线程读取该共享缓冲区,对共享缓冲区的写入和读取由读/写锁组织。
不幸的是,这种方案肯定会导致主线程饿死,因为一次写入必须等待多次读取才能完成。一种可能的解决方案是增加主线程的优先级,因此如果它想写一些东西,它将立即访问共享缓冲区。
根据类似问题的一篇很棒的帖子,我发现可能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
,我所要做的就是以超级用户身份运行程序