Section 7.19.3/7
of c99
states that:
At program start-up, three text streams are predefined and need not be opened explicitly - standard input (for reading conventional input), standard output (for writing conventional output), and standard error (for writing diagnostic output).
As initially opened, the standard error stream is not fully buffered; the standard input and standard output streams are fully buffered if and only if the stream can be determined not to refer to an interactive device.
So that makes sense. If you're pushing your standard output to a file, you want it fully buffered for efficiency.
But I can find no mention in the standard as to whether the output is line buffered or unbuffered when you can't determine the device is non-interactive (ie, normal output to a terminal).
The reason I ask was a comment to my answer here that I should insert an fflush(stdout);
between the two statements:
printf ("Enter number> ");
// fflush (stdout); needed ?
if (fgets (buff, sizeof(buff), stdin) == NULL) { ... }
because I wasn't terminating the printf
with a newline. Can anyone clear this up?
The C99 standard does not specify whether the three standard streams are unbuffered or line buffered: It is up to the implementation. All UNIX implementations I know have a line buffered
stdin
. On Linux,stdout
is line buffered andstderr
unbuffered.As far as I know, POSIX does not impose additional restrictions. POSIX's fflush page does note in the EXAMPLES section:
So the remark that you add
fflush(stdout);
is correct.An alternative could be to make
stdout
unbuffered:But as R. notes you can only do this once, and it must be before you write to
stdout
or perform any other operantion on it. (C99 7.19.5.5 2)I just read a recent thread on
comp.lang.c
about the same thing. One of the remarks: