프로그래밍 언어 및 기술 [언제나휴일]

fclose 함수 [C언어 표준 라이브러리 함수] 본문

C & C++/C언어 표준 라이브러리 함수

fclose 함수 [C언어 표준 라이브러리 함수]

언휴 2024. 1. 29. 14:11

 

fclose 함수 [C언어 표준 라이브러리 함수]
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

테스트를 하실 때는 명령줄에서 하시기 바랍니다.

fclose 함수 실행 화면
fclose 함수 실행 화면