命名空间
变体
操作

stdin, stdout, stderr

来自 cppreference.cn
< c‎ | io
 
 
文件输入/输出
类型和对象
stdinstdoutstderr
        
函数
文件访问
(C95)
无格式输入/输出
(C95)(C95)
(C95)
(C95)(C95)
(C95)
(C95)

格式化输入
 
定义于头文件 <stdio.h>
#define stdin  /* implementation-defined */
(1)
#define stdout /* implementation-defined */
(2)
#define stderr /* implementation-defined */
(3)

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

1)标准输入流关联,用于读取常规输入。在程序启动时,当且仅当可以确定流不引用交互式设备时,该流才被完全缓冲。
2)标准输出流关联,用于写入常规输出。在程序启动时,当且仅当可以确定流不引用交互式设备时,该流才被完全缓冲。
3)标准错误流关联,用于写入诊断输出。在程序启动时,该流未被完全缓冲。

交互式设备的构成由实现定义。

这些宏被展开为 FILE* 类型的表达式。

目录

[编辑] 说明

虽然 POSIX 没有强制要求,但 UNIX 约定是,如果 stdinstdout 与终端关联,则为行缓冲,而 stderr 则为无缓冲。

这些宏可能会展开为可修改的左值。如果修改了任何这些 FILE* 左值,则后续对相应流的操作将导致未指定或未定义的行为。

[编辑] 示例

此示例展示了一个等效于 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);
}

可能的输出

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

[编辑] 参考文献

  • C23 标准 (ISO/IEC 9899:2024)
  • 7.21.1 简介 (p: TBD)
  • 7.21.2 流 (p: TBD)
  • 7.21.2 文件 (p: TBD)
  • C17 标准 (ISO/IEC 9899:2018)
  • 7.21.1 简介 (p: 217-218)
  • 7.21.2 流 (p: 217-219)
  • 7.21.2 文件 (p: 219-221)
  • C11 标准 (ISO/IEC 9899:2011)
  • 7.21.1 简介 (p: 296-298)
  • 7.21.2 流 (p: 298-299)
  • 7.21.2 文件 (p: 300-302)
  • C99 标准 (ISO/IEC 9899:1999)
  • 7.19.1 简介 (p: 262-264)
  • 7.19.2 流 (p: 264-265)
  • 7.19.2 文件 (p: 266-268)
  • C89/C90 标准 (ISO/IEC 9899:1990)
  • 7.9.1 简介
  • 7.9.2 流
  • 7.9.3 文件

[编辑] 参见

对象类型,能够保存控制 C 语言 I/O 流所需的所有信息
(typedef) [编辑]
C++ 文档 关于 stdin, stdout, stderr