Namespaces
Variants

fclose

From cppreference.net
< c ‎ | io
Определено в заголовочном файле <stdio.h>
int fclose ( FILE * stream ) ;

Закрывает заданный файловый поток. Все не записанные буферизованные данные сбрасываются в операционную систему. Все не прочитанные буферизованные данные отбрасываются.

Независимо от того, завершается ли операция успешно, поток больше не ассоциируется с файлом, а буфер, выделенный с помощью setbuf или setvbuf , если таковой имеется, также отсоединяется и освобождается, если использовалась автоматическая аллокация.

Поведение не определено, если значение указателя stream используется после того, как fclose возвращает управление.

Содержание

Параметры

stream - файловый поток для закрытия

Возвращаемое значение

0 при успешном выполнении, EOF в противном случае

Пример

#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

Ссылки

  • Стандарт C23 (ISO/IEC 9899:2024):
  • 7.21.5.1 Функция fclose (стр.: TBD)
  • Стандарт C17 (ISO/IEC 9899:2018):
  • 7.21.5.1 Функция fclose (стр.: TBD)
  • Стандарт C11 (ISO/IEC 9899:2011):
  • 7.21.5.1 Функция fclose (стр: 304)
  • Стандарт C99 (ISO/IEC 9899:1999):
  • 7.19.5.1 Функция fclose (стр: 270)
  • Стандарт C89/C90 (ISO/IEC 9899:1990):
  • 4.9.5.1 Функция fclose

Смотрите также

открывает файл
(функция)
открывает существующий поток с другим именем
(функция)
C++ documentation для fclose