奇怪的是,在某个打印行之后无法打印到标准输出?

标签 c unix 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 是行缓冲的,但 stderr 不是。 C 库将缓冲您的输出,直到找到换行符,然后才将完整的行发送到底层输出。

您会发现,如果将 "test2" 替换为 "test2\n",它将按您的预期打印。您还可以执行 fflush(stdout) 来强制 stdout 刷新而不带换行符。

另一方面,

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

关于奇怪的是,在某个打印行之后无法打印到标准输出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28834891/

相关文章:

c - 为什么我的 C 程序会产生奇怪的 printf 输出?

c - Linux-C : reading from pipe returns first buffer written to it

c - 如何使用环境变量更改 c 程序中的目录?

arrays - 在数组中查找与数组具有相同均值的对

unix - 在 Solaris 上如何找到谁或哪个进程向我的进程发送了信号

windows - 具有不可重定向输出的实用程序 (Windows)

python - 将标准输出重定向到 Python 中的记录器

linux - 难以解决:- “SCP copies files successfully, but files not visible in local computer”

java - java中的getRuntime.exec()是否理解*?

perl - Pod::Simple 没有输出