好的,所以我在打印以调查我的程序停止执行的地方,似乎我不能在某个代码行之后打印到stdout,这段代码行是
printf(") : %d\n", PORTNUMBER);下面是一些例子:
printf("test1");
printf(") : %d\n", PORTNUMBER);
printf("test2");打印test1和端口号,但不打印test2。
这是:
printf(") : %d\n", PORTNUMBER);
fprintf(stdout, "test2");打印端口号,但不打印test2。
这是:
printf(") : %d\n", PORTNUMBER);
fprintf(stderr, "test2");同时打印端口号和test2。
所以我的问题是,到底是怎么回事,是什么让我在打印端口号之后不能写到stdout的?
发布于 2015-03-03 14:57:27
这意味着stdout,而不是stderr,是行缓冲的。C库将缓冲输出,直到找到换行符,然后才将完整的行发送到基础输出。
您将看到,如果您将"test2"替换为"test2\n",它将按您的预期打印。您还可以执行fflush(stdout)来强制stdout在没有换行符的情况下进行刷新。
另一方面,stderr没有缓冲,这就是为什么会立即看到输出给它的原因。
https://stackoverflow.com/questions/28834891
复制相似问题