当前位置:  技术问答>linux和unix

nice()函数源码有两点疑惑

    来源: 互联网  发布时间:2017-03-19

    本文导语:  看这个源码片段: --------------------------------------------------------------- void set_user_nice(task_t *p, long nice) {     unsigned long flags;     prio_array_t *array;     runqueue_t *rq;     int old_prio, new_prio, delta; 1>    if (TASK_...

看这个源码片段:
---------------------------------------------------------------
void set_user_nice(task_t *p, long nice)
{
    unsigned long flags;
    prio_array_t *array;
    runqueue_t *rq;
    int old_prio, new_prio, delta;

1>    if (TASK_NICE(p) == nice || nice  19)
        return;
    
2>    array = p->array;
    if (array)
        dequeue_task(p, array);

3>    old_prio = p->prio;
    new_prio = NICE_TO_PRIO(nice);
    delta = new_prio - old_prio;
    p->static_prio = NICE_TO_PRIO(nice);
    p->prio += delta;

4>    if (array) {
        enqueue_task(p, array);
        if (delta  0 && task_running(rq, p)))
            resched_task(rq->curr);
    }
}
---------------------------------------------------------------
第“3>"处的最后一句“p->prio+=delta”,有两点疑惑:
1,这样一来,一个任务只要调用nice()函数,它的动态优先级立刻被抹去,设置为静态优先级数值。请问是吗?
2,既然p->prio+=delta计算的结果就相当于p->prio=p->static_prio,那为什么不直接写p->prio=p->static_prio,这样意思更明白不是吗?反而p->prio+=delta这句不知所云,难道它有什么特殊含义么?

|
普通进程的static_prio和prio是一样的,实时进程可能不一样
nice()本来就是减少一点优先级的意思,p->prio+=delta也不能算不知所云吧,就是加上这个差值
只是从结果上来看是有点迷糊
也只是某个版本内核是这样写的吧,后面的版本的内核好像不是这样写的

    
 
 

您可能感兴趣的文章:

 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 求助-主机NICE过高 - HP-UX
  • 如何利用nice()改变进程的优先级啊,急,在线等
  • linux线程怎样调整nice值??
  • linux为什么要统计nice值为负的cpu占用情况
  • jQuery智能表单验证 nice Validator


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3