Namespaces
Variants

feof

From cppreference.net
< c ‎ | io
ヘッダーで定義 <stdio.h>
int feof ( FILE * stream ) ;

指定されたファイルストリームの終端に達したかどうかをチェックします。

目次

パラメータ

stream - チェックするファイルストリーム

戻り値

ストリームの終端に達した場合はゼロ以外の値、それ以外の場合は 0

注記

この関数は直近のI/O操作で報告されたストリーム状態のみを報告し、関連するデータソースを検査しません。例えば、直近のI/Oが fgetc であり、ファイルの最終バイトを返した場合、 feof はゼロを返します。次の fgetc は失敗し、ストリーム状態を end-of-file に変更します。その時のみ feof は非ゼロを返します。

一般的な使用法では、入力ストリームの処理はエラー発生時に停止します; feof ferror を使用して、異なるエラー状態を区別します。

#include <stdio.h>
#include <stdlib.h>
int main(void)
{
    const char* fname = "/tmp/unique_name.txt"; // or tmpnam(NULL);
    int is_ok = EXIT_FAILURE;
    FILE* fp = fopen(fname, "w+");
    if (!fp)
    {
        perror("File opening failed");
        return is_ok;
    }
    fputs("Hello, world!\n", fp);
    rewind(fp);
    int c; // note: int, not char, required to handle EOF
    while ((c = fgetc(fp)) != EOF) // standard C I/O file reading loop
        putchar(c);
    if (ferror(fp))
        puts("I/O error when reading");
    else if (feof(fp))
    {
        puts("End of file is reached successfully");
        is_ok = EXIT_SUCCESS;
    }
    fclose(fp);
    remove(fname);
    return is_ok;
}

出力例:

Hello, world!
End of file is reached successfully

参考文献

  • C11規格 (ISO/IEC 9899:2011):
  • 7.21.10.2 feof関数 (p: 339)
  • C99規格 (ISO/IEC 9899:1999):
  • 7.19.10.2 feof関数 (p: 305)
  • C89/C90規格 (ISO/IEC 9899:1990):
  • 4.9.10.2 feof関数

関連項目

エラーをクリア
(関数)
現在のエラーに対応する文字列を stderr に表示
(関数)
ファイルエラーをチェック
(関数)