C 参考手册

位置:首页 > C 参考手册 >文件输入/输出 > fgetc, getc

定义于头文件 <stdio.h>
int fgetc( FILE *stream );
int getc( FILE *stream );

从给定的输入流读取下一个字符。 getc() 可以实现为宏。

参数

stream - 读取字符的来源

返回值

成功时为获得的字符,失败时为 EOF

若文件尾条件导致失败,则另外设置 stream 上的文件尾指示器(见 feof() )。若某些其他错误导致失败,则设置 stream 上的错误指示器(见 ferror() )。

示例

#include <stdio.h>
#include <stdlib.h>
 
int main(void)
{
    FILE* fp = fopen("test.txt", "r");
    if(!fp) {
        perror("File opening failed");
        return EXIT_FAILURE;
    }
 
    int c; // 注意:int,非char,要求处理EOF
    while ((c = fgetc(fp)) != EOF) { // 标准C I/O读取文件循环
       putchar(c);
    }
 
    if (ferror(fp))
        puts("I/O error when reading");
    else if (feof(fp))
        puts("End of file reached successfully");
 
    fclose(fp);
}


引用

  • C11 standard (ISO/IEC 9899:2011):
  • 7.21.7.1 The fgetc function (p: 330)
  • 7.21.7.5 The getc function (p: 332)
  • C99 standard (ISO/IEC 9899:1999):
  • 7.19.7.1 The fgetc function (p: 296)
  • 7.19.7.5 The getc function (p: 297-298)
  • C89/C90 standard (ISO/IEC 9899:1990):
  • 4.9.7.1 The fgetc function
  • 4.9.7.5 The getc function

参阅

stdin 读取一个字符
(函数)
(C11 中移除)(C11 起)
stdin 读取一个字符串
(函数)
将一个字符写入文件流
(函数)
将一个字符送回文件流
(函数)