clearerr | Programming Place Plus C言語編 標準ライブラリのリファレンス

C言語編 標準ライブラリのリファレンス clearerr

先頭へ戻る

clearerr関数

概要 エラー値を初期化する。
ヘッダ stdio.h
形式 void clearerr(FILE* stream);
引数 stream 対象のストリーム。
戻り値
詳細 引数stream のファイル終了指示子と、ファイルエラー指示子を初期化する。
前者は feof関数が真を返す状況を表すフラグ、後者は ferror関数が真を返す状況を表すフラグである。よって、clearerr関数を呼び出した後は、この2つの関数はともに偽を返すようになる。
注意
使用例
#include <stdio.h>
#include <stdlib.h>

int main(void)
{
    FILE* fp;
    int c;

    fp = fopen( "test.txt", "r" );
    if( fp == NULL ){
        exit( EXIT_FAILURE );
    }

    while( 1 ){
        c = fgetc(fp);
        if (c == EOF) {
            if (feof(fp)) {
                break;
            }
            else if (ferror(fp)) {
                puts("File Read Error");
                clearerr(fp);
                rewind(fp);
                break;
            }
            else {
                exit(EXIT_FAILURE);
            }
        }
        printf( "%c", c );
    }

    if( fclose( fp ) == EOF ){
        fputs( "ファイルクローズに失敗しました。\n", stderr );
        exit( EXIT_FAILURE );
    }

    return 0;
}

実行結果:

test message
関連
解説章


参考リンク



更新履歴

'2018/4/6 「使用例」での fgetc関数のエラーチェックの方法を修正。

'2018/1/22 新規作成。



標準ライブラリのリファレンス(名前順)のトップページへ

標準ライブラリのリファレンス(ヘッダ別)のトップページへ

C言語編のトップページへ

Programming Place Plus のトップページへ


このエントリーをはてなブックマークに追加
rss1.0 取得ボタン RSS