您的位置:首页 > 其它

线程的调度策略2

2011-07-29 17:54 489 查看
2.6 Linux有3个scheduling policy

#define SCHED_OTHER 0

#define SCHED_FIFO 1

#define SCHED_RR 2

第一个是普通进程的,后两个是实时进程的

一般的进程都是普通进程,系统中出现实时进程的机会很少

2.6 Linux有140个优先级

后40个和nice value一一对应,属于SCHED_OTHER

前100个属于SCHED_FIFO, SCHED_RR

FIFO,RR这两个的区别学过OS应该都知道吧

一个是先进先出,一个是round robin

因为SCHED_FIFO, SCHED_RR优先级高于所有SCHED_OTHER的进程

所以只要他们能够运行,在他们运行完之前,所有SCHED_OTHER的进程的都没有得到执行的机会

可以以root身份试一下这个小程序,普通用户无法调用sched_setscheduler系统调用

不过做好准备,一但运行起来之后,要结束就只有按机箱上的reset

#include<sched.h>

#include<unistd.h>

int main(){

struct sched_param sp;

sp.sched_priority = 99;

sched_setscheduler(0, SCHED_RR, &sp);

printf("%d\n", sched_getscheduler(0));

for(;;);

return 0;

}

sched_setscheduler用法说明:

  #include <sched.h>

int sched_setscheduler(pid_t pid, int policy,

const struct sched_param *param);

sched_setscheduler()函数将pid所指定进程的调度策略和调度参数分别设置为param指向的sched_param结构中指定的policy和参数。sched_param结构中的sched_priority成员的值可以为任何整数,该整数位于policy所指定调度策略的优先级范围内(含边界值)。policy参数的可能值在头文件中定义。

如果存在pid所描述的进程,将会为进程ID等于pid的进程设置调度策略和调度参数。

如果pid为零,将会为调用进程设置调度策略和调度参数。

如果进程pid含多个进程或轻量进程(即该进程是多进程的),此函数将影响进程中各个子进程。

更改其他进程的调度参数需要有相应的特权。调用进程必须具有相应的特权,或者是具有PRIV_RTSCHED权限的组的成员,猜能成功调用sched_setscheduler()。如果sched_setscheduler()函数成功地将pid所指定调度策略和调度参数分别设置为policy和结构param指定值 ,则该函数调用成功。

例子:更改调用进程以使用最强的FIFO优先级,如下所示:

#include <sched.h>

int main(int argc,char *argv[])

{

struct sched_param param;

int maxpri;

maxpri = sched_get_priority_max(SCHED_FIFO);//»ñÈ¡×î´óÖµ

if(maxpri == -1)

{

perror("sched_get_priority_max() failed");

exit(1);

}

param.sched_priority = maxpri;

if (sched_setscheduler(getpid(), SCHED_FIFO, ¶m) == -1) //设置优先级

{

perror("sched_setscheduler() failed");

exit(1);

}

}

获取调度策略

获取调度策略sched_getscheduler()函数声明如下:

/* Retrieve scheduling algorithm for a particular purpose. */

#include <sched.h>

int sched_getscheduler(pid_t pid);

sched_getscheduler()函数返回pid所指定进程的调度策略。

1.如果存在pid所描述的进程,将返回进程ID等于pid的进程的调度策略。

2.如果pid为零,将返回调用进程的调度策略。

3.如果进程pid包含多个进程或轻量进程,此函数只返回进程调度策略和优先级。

目标进程的各个进程或轻量级进程具有其自身的调度策略和优先级,它们可能与当前进程的调度策略和优先级不同。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: