奇怪的是,在某个打印行之后不能打印到标准输出吗?
Can oddly not print to stdout after a certain print line?
好的,所以我正在打印以调查我的程序停止执行的位置,看来我根本无法在某个代码行之后打印到标准输出,该代码行是
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
,而不是stderr
,是行缓冲的。 C 库将缓冲您的输出,直到找到换行符,然后才将完整的行发送到底层输出。
您会看到,如果将 "test2"
替换为 "test2\n"
,它将按您预期的方式打印。您还可以执行 fflush(stdout)
强制 stdout
在没有换行符的情况下刷新。
另一方面,stderr
是无缓冲的,这就是为什么会立即看到输出到它的原因。
好的,所以我正在打印以调查我的程序停止执行的位置,看来我根本无法在某个代码行之后打印到标准输出,该代码行是
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
,而不是stderr
,是行缓冲的。 C 库将缓冲您的输出,直到找到换行符,然后才将完整的行发送到底层输出。
您会看到,如果将 "test2"
替换为 "test2\n"
,它将按您预期的方式打印。您还可以执行 fflush(stdout)
强制 stdout
在没有换行符的情况下刷新。
stderr
是无缓冲的,这就是为什么会立即看到输出到它的原因。