微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

调度过程中的先进先出?

如何解决调度过程中的先进先出?

我的教授展示了以下代码并声称在子进程开始工作后父进程不再运行(假设我们在单核 cpu 上运行)。

static int g_alarm = 0;

void alrm_handler(int signo) {
    g_alarm = 1;
}

void son() { // assume executing as superuser
    struct sched_param param;
    param.sched_priority = 50;
    sched_setscheduler(getpid(),SCHED_FIFO,&param);

    kill(getppid(),SIG_ALRM);
    sched_yield();

    printf("msg1\n");
    while (1) /*endless looP*/;
    exit(0);
}

int main() {
    signal(SIG_ALRM,alrm_handler);
    int son_pid = fork();
    if (son_pid == 0)
        son();
    waipid(son_pid)
    printf("msg2\n");
    return 0;
}

我完全不明白为什么这种说法是正确的。

  1. 运行时:

    sched_setscheduler(getpid(),&param);
    

那么 SCHED_FIFO 会影响正在运行的 cpu 子进程,对吗?

  1. 如果是,则子进程总是转到等待作业列表的末尾,因此,由于我们使用 FIFO,父进程将首先运行。

有人能帮我解决这个巨大的矛盾吗?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。