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, &param) == -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包含多个进程或轻量进程,此函数只返回进程调度策略和优先级。

目标进程的各个进程或轻量级进程具有其自身的调度策略和优先级,它们可能与当前进程的调度策略和优先级不同。

 

 


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
`sched_setscheduler` 是 Linux 系统调度程序的一个函数,它允许进程设置自己的调度策略和优先级。该函数可以用于实时进程或非实时进程。它的原型如下: ```c int sched_setscheduler(pid_t pid, int policy, const struct sched_param *param); ``` 其中,`pid` 是要设置的进程的 ID,`policy` 是调度策略,可以是 `SCHED_FIFO`、`SCHED_RR` 或 `SCHED_OTHER` 中的一个,`param` 是一个指向 `sched_param` 结构的指针,包含了进程的优先级等信息。 - `SCHED_FIFO`:先进先出调度策略。进程按照它们加入运行队列的顺序进行调度。如果一个进程一直保持在运行状态,那么它将一直占用 CPU 资源,其他进程可能得不到运行机会。 - `SCHED_RR`:时间片轮转调度策略。每个进程被分配一个时间片,当时间片用完后,进程被放回队列尾部,等待下一次调度。这种策略确保每个进程都有机会执行,并且可以防止某个进程长时间占用 CPU。 - `SCHED_OTHER`:普通调度策略。这是默认的调度策略,它不保证任何特定的调度行为。 `param` 结构包含了以下字段: ```c struct sched_param { int sched_priority; // 进程优先级 }; ``` `sched_priority` 字段用于设置进程的优先级。在 `SCHED_FIFO` 和 `SCHED_RR` 策略中,较高的优先级意味着进程更容易获得 CPU 时间片。在 `SCHED_OTHER` 策略中,该值不起作用。 调用 `sched_setscheduler` 函数后,相应的进程将按照指定的调度策略和优先级进行运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值