fgetc, getc
From cppreference.net
|
헤더 파일에 정의됨
<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
|
|