Linux内核的三种调度策略:
- SCHED_OTHER 分时调度策略,
- SCHED_FIFO实时调度策略,先到先服务。一旦占用cpu则一直运行。一直运行直到有更高优先级任务到达或自己放弃
- SCHED_RR实时调度策略,时间片轮转。当进程的时间片用完,系统将重新分配时间片,并置于就绪队列尾。放在队列尾保证了所有具有相同优先级的RR任务的调度公平
设置和获取优先级通过以下两个函数
int pthread_attr_setschedparam(pthread_attr_t *attr, const struct sched_param *param);
int pthread_attr_getschedparam(const pthread_attr_t *attr, struct sched_param *param);
param.sched_priority = 51; //设置优先级
系统创建线程时,默认的线程是SCHED_OTHER。所以如果我们要改变线程的调度策略的话,可以通过下面的这个函数实现
int pthread_attr_setschedpolicy(pthread_attr_t *attr, int policy);
static void set_thread_policy(pthread_attr_t *attr,int policy)
{
int rs = pthread_attr_setschedpolicy(attr,policy);
assert(rs==0);
get_thread_policy(attr);
}
int main(void)
{
pthread_attr_t attr;
int rs;
rs = pthread_attr_init(&attr);
assert(rs==0);
printf("Set thread policy\n");
printf("set SCHED_RR policy\n");
set_thread_policy(&attr,SCHED_RR);
rs = pthread_attr_destroy(&attr);
assert(rs==0);
return 0;
}
网友评论