调度过程中的先进先出?

问题描述

我的教授展示了以下代码并声称在子进程开始工作后父进程不再运行(假设我们在单核 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 (将#修改为@)