Defined in header <stdio.h> | ||
|---|---|---|
#define stdin /* implementation-defined */ | (1) | |
#define stdout /* implementation-defined */ | (2) | |
#define stderr /* implementation-defined */ | (3) |
Three text streams are predefined. These streams are implicitly opened and unoriented at program startup.
What constitutes an interactive device is implementation-defined.
These macros are expanded to expressions of type FILE*.
Although not mandated by POSIX, the UNIX convention is that stdin and stdout are line-buffered if associated with a terminal and stderr is unbuffered.
These macros may be expanded to modifiable lvalues. If any of these FILE* lvalue is modified, subsequent operations on the corresponding stream result in unspecified or undefined behavior.
This example shows a function equivalent to printf.
#include <stdarg.h>
#include <stdio.h>
int my_printf(const char * restrict fmt, ...)
{
va_list vl;
va_start(vl, fmt);
int ret = vfprintf(stdout, fmt, vl);
va_end(vl);
return ret;
}
int main(void)
{
my_printf("Rounding:\t%f %.0f %.32f\n", 1.5, 1.5, 1.3);
my_printf("Padding:\t%05.2f %.2f %5.2f\n", 1.5, 1.5, 1.5);
my_printf("Scientific:\t%E %e\n", 1.5, 1.5);
my_printf("Hexadecimal:\t%a %A\n", 1.5, 1.5);
}Possible output:
Rounding: 1.500000 2 1.30000000000000004440892098500626 Padding: 01.50 1.50 1.50 Scientific: 1.500000E+00 1.500000e+00 Hexadecimal: 0x1.8p+0 0X1.8P+0
| object type, capable of holding all information needed to control a C I/O stream (typedef) |
|
C++ documentation for stdin, stdout, stderr |
|
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/c/io/std_streams