总之,我正在设计一个键值服务器,当我编写客户端时,我发现了一个非常奇怪的事情,请看简化的代码:
while(1)
{
printf("->:");
read(STDIN_FILENO, buf, sizeof(buf));
write(client_sock, buf, sizeof(buf));
int m = read(client_sock, buf, sizeof(buf));
buf[m] = '\0';
printf("%s", buf);
}当我运行程序时,它首先要求输入,所以我输入了一些东西,但什么也没有发生!(服务器运行得很好,当我使用其他客户端时,它能很好地回显一些东西)
然后我只修改了一行代码:
printf("\n->:");那么它运行的很好!为什么?为什么"\n“可以更改输出?我猜可能是read(),但我无法解释它
发布于 2011-12-18 14:13:44
printf(3)是C标准IO库的一部分,它执行内部缓冲以提供性能改进。
有三种类型的缓冲:无、行和块。
应用哪个缓冲部分地取决于正被写入的描述符是否是2的,以及它是否连接到终端。(请参阅isatty(3)。)
如果对stderr (2)执行打印,则不会进行缓冲。
如果打印到任何其他描述符,那么无论它是不是终端,行为都会发生变化:如果输出是终端,则输出是行缓冲的。如果输出不是终端(文件、管道、套接字等)然后对输出进行块缓冲。
在行缓冲时,它会等待\n,然后再打印任何内容。(或者,如果您在发送\n之前编写了足够的内容使内部缓冲区溢出。)
相反,我会推荐以下内容:
printf("->:");
fflush(stdout);
read(STDIN_FILENO, buf, sizeof(buf));
/* ... */
printf("%s\n", buf);这是一个很小的更改;在程序启动时,您不会得到一个没有意义的空行,并且提示符应该会出现。非常迅速。
您可以在启动时使用setvbuf(3)函数更改流的缓冲一次,如果您愿意,则永远不需要再次刷新它。
int err = setvbuf(stdout, NULL, _IONBF, 0);
/* check err */发布于 2011-12-18 14:12:28
默认情况下,标准输出是行缓冲的。如果您没有编写完整的行,则输出将保存在缓冲区中,直到您编写完整的行。您可以使用fflush刷新流,也可以使用setbuf更改缓冲模式。
https://stackoverflow.com/questions/8550116
复制相似问题