stdin, stdout, stderr

来自cppreference.com
< cpp‎ | io‎ | c


 
 
 
C 风格 I/O
类型与对象
stdinstdoutstderr
函数
文件访问
直接输入/输出
无格式输入/输出
有格式输入
(C++11)(C++11)(C++11)    
(C++11)(C++11)(C++11)    
 
在标头 <cstdio> 定义
#define stdin  /* 由实现定义 */
(1)
#define stdout /* 由实现定义 */
(2)
#define stderr /* 由实现定义 */
(3)

预定义了三个文本流。这些流在程序启动时隐式打开,且为无取向。

1)标准输入流关联,用于读取约定的输入。程序启动时,当且仅当能确定流不代表交互式设备时该流为完全缓冲。
2)标准输出流关联,用于写入约定的输出。程序启动时,当且仅当能确定流不代表交互式设备时该流为完全缓冲。
3)标准错误流关联,用于写入诊断输出。程序启动时,该流不为完全缓冲。

何者组成交互式设备是实现定义的。

这些宏展开成 std::FILE* 类型的表达式。

注解

尽管 POSIX 不强制,但 UNIX 的约定是 stdinstdout 若与终端关联则为行缓冲,而 stderr 为无缓冲。

这些宏可能展开成可修改左值。若修改任何这些 std::FILE* 左值,则对应的流上的后续操作导致未指明或未定义行为。

示例

此示例展示类似于 std::printf 的函数。

#include <concepts>
#include <cstdio>
#include <type_traits>
 
template<typename T>
concept IsPrintable = std::integral<T> or std::floating_point<T> or std::is_pointer_v<T>;
 
int my_printf(char const* const format, IsPrintable auto const ... arguments)
{
    return std::fprintf(stdout, format, arguments...);
}
 
int main(int argv, char*[])
{
    my_printf("字符串和字符:\t%s %c\n", "hello", 'x');
    my_printf("舍入:\t\t%f %.0f %.32f\n", 1.5, 1.5, 1.3);
    my_printf("填充:\t\t%05.2f %.2f %5.2f\n", 1.5, 1.5, 1.5);
    my_printf("科学表示:\t%E %e\n", 1.5, 1.5);
    my_printf("十六进制:\t%a %A 0x%X\n", 1.5, 1.5, &argv);
}

可能的输出:

字符串和字符:	hello x
舍入:		1.500000 2 1.30000000000000004440892098500626
填充:		01.50 1.50  1.50
科学表示:	1.500000E+00 1.500000e+00
十六进制:	0x1.8p+0 0X1.8P+0 0x2CFB41BC

参阅

从标准 C 输入流 stdin 中读取
(全局对象)
写入到标准 C 输出流 stdout
(全局对象)
写入到标准 C 错误流 stderr,无缓冲
(全局对象)
写入到标准 C 错误流 stderr
(全局对象)
打印有格式输出到 stdout、文件流或缓冲区
(函数)
对象类型,足以保有控制 C 输入/输出流所需的全部信息
(typedef)