Поделиться через


clearerr

Сбрасывает индикатор ошибки для потока. Существует более безопасная версия этой функции; см. раздел clearerr_s.

void clearerr(
   FILE *stream 
);

Параметры

  • stream
    Указатель на структуру FILE.

Заметки

Функция clearerr сбрасывает индикатор ошибки и индикатор конца файла для stream. Индикаторы ошибки не очищаются автоматически; когда установлен индикатор ошибки для определенного потока, операции в этом потоке будут продолжать возвращать значение ошибки до вызова clearerr, fseek, fsetpos или rewind.

Если параметр stream имеет значение NULL, вызывается обработчик недопустимого параметра, как описано в разделе Проверка параметров. Если выполнение может быть продолжено, функция устанавливает errno в значение EINVAL и завершается. Дополнительные сведения о errno и кодах ошибок см. в разделе errno Constants.

Существует более безопасная версия этой функции; см. раздел clearerr_s.

Требования

Подпрограмма

Обязательный заголовок

clearerr

<stdio.h>

Дополнительные сведения о совместимости см. в разделе Совместимость во введении.

Пример

// 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-d87a68a5ce19467d99ed90855dbc61dc-8e736f637d774905ad2725059e993003

Эквивалент в .NET Framework

Неприменимо. Для вызова стандартной функции C используйте PInvoke. Дополнительные сведения см. в разделе Примеры вызовов неуправляемого кода.

См. также

Ссылки

Обработка ошибок (CRT)

Потоковый ввод-вывод

_eof

feof

ferror

perror, _wperror