缓冲IO流在fork()上有一个奇怪的行为。
在下面显示的示例代码片段中,正在读取的文件大小为252字节。在fork()之后,孩子成功地读取了一行并在屏幕上打印。但是,当控制返回到父进程时,由于某种原因,文件偏移量被设置为文件的末尾,父进程无法从流中读取任何内容。如果fork()创建了一个文件描述符的dup (这在使用系统调用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);
}
}发布于 2013-11-26 04:02:59
子进程中的fgets()是完全缓冲的,因为它正在从文件中读取数据。在我的系统上,一个完全缓冲的缓冲区的大小是1024..So,一个read()在fgets()缓冲区中包含文件的全部内容(252字节)。因此,当控件从子级返回到父级时,偏移量将设置为文件的末尾。
在子进程返回之前,在子进程中执行fflush(),可以确保fgets()缓冲区中的数据被丢弃,因此当控件到达父进程时,文件offest会被正确地设置回去。
https://stackoverflow.com/questions/20185750
复制相似问题