可以奇怪的是在某个打印线后不能打印到标准输出?

时间:2015-03-03 14:54:35

标签: c unix stdout

好的,所以我正在打印以调查我的程序停止执行的位置,看来我根本无法在某个代码行之后打印到stdout,该代码行是

printf(") : %d\n", PORTNUMBER);

一些例子:

printf("test1");
printf(") : %d\n", PORTNUMBER);
printf("test2");

打印test1和portnumber,但不打印test2。

此:

printf(") : %d\n", PORTNUMBER);
fprintf(stdout, "test2");

打印portnumber,但不打印test2。

此:

printf(") : %d\n", PORTNUMBER);
fprintf(stderr, "test2");

打印端口号和test2。

所以我的问题是,这里发生了什么,在打印端口号后,是什么原因导致我无法写入stdout?

1 个答案:

答案 0 :(得分:1)

这意味着stdout,而不是stderr,是行缓冲的。 C库将缓冲输出,直到找到换行符,然后才将完整的行发送到基础输出。

如果您将"test2"替换为"test2\n",您会看到它会按预期打印。您也可以执行fflush(stdout)强制stdout在没有换行符的情况下进行刷新。

另一方面,

stderr是无缓冲的,这就是为什么会立即看到它的输出。