fclose

ファイルをクローズ (close) します.

#include <stdio.h>
int fclose(
    FILE *stream
);

fclose 関数は stream が指す ストリームに結び付けられたファイルをクローズ (close) します.

ストリームに対してバッファリング (buffering) されただけでまだ書き込まれていないデータがあった場合には,そのデータをファイルに書き込みます. (正確には書き込まれていないデータをホスト環境に引渡し,ホスト環境がデータをファイルに書き込みます.)
また,バッファリングされただけでまだ読み取られていないデータは破棄します.

戻り値

  • 操作が成功したとき: 0
  • 操作が失敗したとき: EOF

C言語サンプルプログラム

fclose 関数を使用したサンプルプログラムを以下に示します.以下のサンプルプログラムでは fopen でファイルをオープンし,fputs でファイルに文字列を書き込んだ後,fclose でファイルをクローズしています.

/* header files */
#include <stdio.h>
#include <stdlib.h>

/* main */
int main(void) {
    FILE *fp;
    char *filename = "sample.txt";
    char *writeline = "I love Snoopy!";

    /* ファイルのオープン */
    if ((fp = fopen(filename, "w")) == NULL) {
        fprintf(stderr, "%sのオープンに失敗しました.\n", filename);
        exit(EXIT_FAILURE);
    }

    /* 文字列をsample.txtに書き込む */
    fputs(writeline, fp);

    /* ファイルのクローズ */
    fclose(fp);

    return EXIT_SUCCESS;
}

実行例

sample.txt には以下のように書き込まれます.

I love Snoopy!