Namespaces
Variants

fgetc, getc

From cppreference.net
< c ‎ | io
헤더 파일에 정의됨 <stdio.h>
int fgetc ( FILE * stream ) ;
(1)
int getc ( FILE * stream ) ;
(2)
1) 주어진 입력 스트림에서 다음 문자를 읽습니다.
2) fgetc 와 동일하지만, getc 가 매크로로 구현된 경우 스트림을 여러 번 평가할 수 있으므로, 해당 인수는 부작용이 있는 표현식이어서는 안 됩니다.

목차

매개변수

stream - 문자를 읽어올 스트림

반환값

성공 시, 획득한 문자를 unsigned char 로 변환한 int 값을 반환합니다. 실패 시, EOF 를 반환합니다.

실패가 파일 끝(end-of-file) 조건에 의해 발생한 경우, 추가적으로 eof 지시자를 설정합니다 ( feof() 참조). 이는 stream 에 적용됩니다. 실패가 다른 오류에 의해 발생한 경우, error 지시자를 설정합니다 ( ferror() 참조). 이는 stream 에 적용됩니다.

예제

#include <stdio.h>
#include <stdlib.h>
int main(void)
{
    const char* fname = "/tmp/unique_name.txt"; // or tmpnam(NULL);
    int is_ok = EXIT_FAILURE;
    FILE* fp = fopen(fname, "w+");
    if (!fp)
    {
        perror("File opening failed");
        return is_ok;
    }
    fputs("Hello, world!\n", fp);
    rewind(fp);
    int c; // note: int, not char, required to handle EOF
    while ((c = fgetc(fp)) != EOF) // standard C I/O file reading loop
        putchar(c);
    if (ferror(fp))
        puts("I/O error when reading");
    else if (feof(fp))
    {
        puts("End of file is reached successfully");
        is_ok = EXIT_SUCCESS;
    }
    fclose(fp);
    remove(fname);
    return is_ok;
}

가능한 출력:

Hello, world!
End of file is reached successfully

참고문헌

  • C23 표준 (ISO/IEC 9899:2024):
  • 7.21.7.1 fgetc 함수 (p: TBD)
  • 7.21.7.5 getc 함수 (p: TBD)
  • C17 표준 (ISO/IEC 9899:2018):
  • 7.21.7.1 The fgetc function (p: 240-241)
  • 7.21.7.5 The getc function (p: 242)
  • C11 표준 (ISO/IEC 9899:2011):
  • 7.21.7.1 fgetc 함수 (p: 330)
  • 7.21.7.5 getc 함수 (p: 332)
  • C99 표준 (ISO/IEC 9899:1999):
  • 7.19.7.1 fgetc 함수 (p: 296)
  • 7.19.7.5 getc 함수 (p: 297-298)
  • C89/C90 표준 (ISO/IEC 9899:1990):
  • 4.9.7.1 The fgetc function
  • 4.9.7.5 The getc function

참고 항목

stdin에서 문자를 읽어들임 stdin
(함수)
(C11에서 제거됨) (C11)
stdin에서 문자열을 읽어들임 stdin
(함수)
파일 스트림에 문자를 기록함
(함수)
문자를 파일 스트림으로 되돌림
(함수)
C++ documentation for fgetc , getc