0

缓冲 IO 流在fork().

在下面显示的示例片段中,正在读取的文件大小为 252 字节。之后fork(),孩子正在成功地阅读一行并在屏幕上打印。但是,当控件返回父进程时,由于某种原因,文件偏移量设置为文件末尾,父进程无法从流中读取任何内容。如果fork()创建文件描述符的副本(这可以很好地使用系统调用read()和复制相同的程序write()),人们会期望父进程从流中读取下一行,但这似乎不会发生在这里。当控件到达父级时,文件偏移量设置为文件末尾。有人可以对此有所了解吗?

int main(void)
{    
    char buffer[80];
    FILE *file;
    pid_t pid;
    int status;

    /* Open the file: */
    file = fopen(FILENAME, "r");

    if ((pid = fork()) == 0){
        fgets(buffer, sizeof(buffer), file);
        printf("%s", buffer);
    }
    else{
        waitpid(pid, &status, 0);
        printf("Offset [%d]\n", ftell(file));

        fgets(buffer, sizeof(buffer), file);
        printf("%s", buffer);
    }
}
4

1 回答 1

0

子进程中的 fgets() 在从文件中读取数据时被完全缓冲。在我的系统上,一个完全缓冲的缓冲区大小为 1024 ..因此,单个 read() 在 fgets() 缓冲区中具有文件的全部内容(252 字节)。因此,当控件从子级返回父级时,偏移量设置为文件末尾。

在子进程中执行 fflush(),在它返回之前,确保 fgets() 缓冲区中的数据被丢弃,因此当控件到达父进程时,文件 offest 被正确设置。

于 2013-11-25T20:02:58.857 回答