clearerr

ストリームのエラー インジケーターをリセットします。 この関数のセキュリティが強化されたバージョンについては、「clearerr_s」を参照してください。

void clearerr(
   FILE *stream 
);

パラメーター

  • stream
    FILE 構造体へのポインター。

解説

clearerr 関数は、stream のエラー インジケーターおよび EOF (end-of-file) インジケーターをリセットします。 エラー インジケーターは自動的にクリアされないため、指定されたストリームのエラー インジケーターが設定されると、そのストリームに対する操作は、clearerr、fseek、fsetpos、または rewind のいずれかが呼び出されるまでエラー値を返し続けます。

stream が NULL の場合は、「パラメーターの検証」に説明されているように、無効なパラメーター ハンドラーが呼び出されます。 実行の継続が許可された場合、この関数は errno を EINVAL に設定し、戻ります。 errno とエラー コードの詳細については、「errno 定数」を参照してください。

この関数のセキュリティが強化されたバージョンを使用できるようになりました。「clearerr_s」を参照してください。

必要条件

ルーチン

必須ヘッダー

clearerr

<stdio.h>

互換性の詳細については、「C ランタイム ライブラリ」の「互換性」を参照してください。

使用例

// crt_clearerr.c
// This program creates an error
// on the standard input stream, then clears
// it so that future reads won't fail.

#include <stdio.h>

int main( void )
{
   int c;
   // Create an error by writing to standard input.
   putc( 'c', stdin );
   if( ferror( stdin ) )
   {
      perror( "Write error" );
      clearerr( stdin );
   }

   // See if read causes an error.
   printf( "Will input cause an error? " );
   c = getc( stdin );
   if( ferror( stdin ) )
   {
      perror( "Read error" );
      clearerr( stdin );
   }
   else
      printf( "No read error\n" );
}
  n

FakePre-0886b4e9e9bf460bb255e1aa9c6fd635-5fc7748f322f466f9425d729d2adf6a7

同等の .NET Framework 関数

該当なし標準 C 関数を呼び出すには、PInvoke を使用します。詳細については、「プラットフォーム呼び出しの例」を参照してください。

参照

参照

エラー処理 (CRT)

ストリーム入出力

_eof

feof

ferror

perror、_wperror