为什么printf在调用后不刷新,除非格式字符串中有换行符?这是POSIX行为吗?如何让printf每次都立即刷新?


当前回答

Stdout是缓冲的,因此只在打印换行符后输出。

要获得立即输出,可以:

打印到标准错误。 使stdout无缓冲。

其他回答

stdout流在默认情况下是行缓冲的,因此只会在它到达换行符后(或当它被告知时)显示缓冲区中的内容。你有几个选项可以立即打印:

使用fprintf打印到stderrinstead (stderr默认是无缓冲的): fprintf(stderr,“我将立即被打印”); 在需要时使用fflush刷新标准输出: printf("Buffered, will flush "); 。fflush (stdout);//现在打印stdout缓冲区中的所有内容 使用setbuf禁用stdout的缓冲: setbuf (stdout, NULL); 或者使用更灵活的setvbuf: setvbuf(stdout, NULL, _IONBF, 0);

Stdout是缓冲的,因此只在打印换行符后输出。

要获得立即输出,可以:

打印到标准错误。 使stdout无缓冲。

这样做可能是为了提高效率,也因为如果有多个程序写入一个TTY,这样就不会让一行上的字符相互交错。所以如果程序A和B输出,你通常会得到:

program A output
program B output
program B output
program A output
program B output

这太糟糕了,但总比

proprogrgraam m AB  ououtputputt
prproogrgram amB A  ououtputtput
program B output

请注意,它甚至不保证在换行上刷新,因此如果刷新对您很重要,则应该显式刷新。

你可以fprintf到stderr,这是无缓冲的。或者您可以在需要时刷新stdout。或者你可以将stdout设置为unbuffered。

注意:Microsoft运行时库不支持行缓冲,因此printf(“将立即打印到终端”):

https://learn.microsoft.com/en-us/cpp/c-runtime-library/reference/setvbuf