언어 자료구조 알고리즘/C11 표준 라이브러리 함수

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

언제나휴일 2016. 1. 3. 14:57
반응형

fclose


헤더 파일

[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - STDIO.H

 

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


사용한 함수 

[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - printf

[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - fopen_s

[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - perror

[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - feof 

[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - getc

[언어 자료구조 알고리즘/C11 표준 라이브러리 함수] - putchar

반응형