int fclose(FILE *fp); 파일 스트림을 닫는 함수
입력 매개 변수 리스트
fp 파일 스트림 포인터
반환 값
성공 시 0, 에러가 있다면 EOF(EOF는 -1)
사용 예
//C언어 표준 라이브러리 함수 가이드 //int fclose(FILE *fp); 파일 스트림을 닫는 함수 //파일을 읽어 라인 번호와 함께 표준 출력 스트림(콘솔)에 출력 #include <stdio.h> int main(int argc, char **argv) { FILE * fp; char ch; int line_no = 1, count = 0; if (argc != 2)//command line에서 인자를 잘못 사용 { printf("사용법: %s [원본 파일명]", argv[0]); return; } //원본 파일 읽기 모드로 열기 fopen_s(&fp, argv[1], "r"); if (fp == NULL)//열기 실패일 때 { perror("fopen 실패");//에러 메시지 출력 return; } printf("== %s 파일 내용 \n", argv[1]); printf("<%d>: ", line_no); //라인 번호 출력 while (!feof(fp)) //원본 파일 스트림이 EOF를 만나지 않았다면 반복 { ch = getc(fp); //원본 파일에서 문자 하나 읽기 putchar(ch);//읽어온 문자 출력 if (ch == '\n') //개행 문자일 때 { line_no++; //라인 번호 1 증가 printf("<%d>: ", line_no); //라인 번호 출력 } count++;//문자 개수 1 증가 } fclose(fp); //파일 스트림 닫기 printf("\n\n총 라인 수:%d 문자 수:%d\n", line_no, count); return 0; }
명령줄
> ex_fclose input.txt
input.txt 내용
#include <stdio.h> int fclose(FILE *stream); 설명 파일 스트림을 닫는 함수입니다. 아직 처리하지 않은 데이터가 읽기 버퍼에 있으면 버립니다. 아직 처리하지 않은 데이터가 쓰기 버퍼에 있으면 닫기 전에 기록합니다. 파일 스트림을 열면서 할당한 자원은 자동으로 해제합니다.
출력
== input.txt 파일 내용 <1>: #include <stdio.h> <2>: int fclose(FILE *stream); <3>: 설명 <4>: 파일 스트림을 닫는 함수입니다. <5>: 아직 처리하지 않은 데이터가 읽기 버퍼에 있으면 버립니다. <6>: 아직 처리하지 않은 데이터가 쓰기 버퍼에 있으면 닫기 전에 기록합니다. <7>: 파일 스트림을 열면서 할당한 자원은 자동으로 해제합니다. 총 라인 수:7 문자 수:263
테스트를 하실 때는 명령줄에서 하시기 바랍니다.