0
#include<apue.h>
#include<signal.h>

static void charatatime(char *str)
{
    char *ptr;
    int c;
    setbuf(stdout,NULL);
    for (ptr = str;(c = *ptr++) != 0;)
        putc(c,stdout);
}

int main(int argc , char *argv[])
{
    pid_t   pid;
    int i;
    TELL_WAIT();

    if ((pid = fork()) < 0)
        err_sys("fork error");
    else if (pid == 0)
    {

        for (i = 0;i < 10;++i)
        {
            WAIT_PARENT();
            charatatime("ouput from child\n");
        }

        exit(0);
    }
    else
    {

        for (i = 0;i < 10;++i)
        {
            charatatime("output from parent\n");
            TELL_CHILD(pid);
        }
    }
    return 0;
}

它只需打印两次而没有任何循环即可正常工作。但是当我尝试使用for循环打印更多次时似乎很糟糕......我认为父进程应该在TELL_CHILD(pid)完成后等待子进程......

4

1 回答 1

1

您的问题是,在写入之后,父母不会等待孩子接管。所以你的代码只确保孩子在父母至少写过一次之后才会写。

我无法测试代码所以检查错误,但也许这样的事情会起作用:

#include<apue.h>
#include<signal.h>

static void charatatime(char *str)
{
    char *ptr;
    int c;
    setbuf(stdout,NULL);
    for (ptr = str;(c = *ptr++) != 0;)
        putc(c,stdout);
}

int main(int argc , char *argv[])
{
    pid_t   pid;
    int i;
    TELL_WAIT();

    if ((pid = fork()) < 0)
        err_sys("fork error");
    else if (pid == 0)
    {
        TELL_PARENT();

        for (i = 0;i < 10;++i)
        {
            WAIT_PARENT();
            charatatime("ouput from child\n");
            TELL_PARENT();
        }

        exit(0);
    }
    else
    {

        for (i = 0;i < 10;++i)
        {
            WAIT_CHILD(pid);
            charatatime("output from parent\n");
            TELL_CHILD(pid);
        }
    }
    return 0;
}
于 2012-09-27T14:15:06.913 回答