FCLOSE(3) Руководство программиста Linux FCLOSE(3)

ИМЯ

fclose - закрывает поток

ОБЗОР

#include <stdio.h>

int fclose(FILE *stream);

ОПИСАНИЕ

Функция fclose() сбрасывает (flushes) поток, указанный в stream (записывает все буферизированные выходные данные с помощью fflush(3)) и закрывает связанный с ним файловый дескриптор.

ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ

При успешном выполнении возвращается нулевое значение. В противном случае возвращается EOF и errno присваивается код ошибки. В любом случае, дальнейшие попытки доступа (включая ещё один вызов fclose()) к потоку приведут к неопределенному результату.

ОШИБКИ

В stream указан неверный дескриптор файла.

Функция fclose() при ошибках может установить errno в значение, соответствующее ошибкам функций close(2), write(2) или fflush(3).

АТРИБУТЫ

Описание терминов данного раздела смотрите в attributes(7).

Интерфейс Атрибут Значение
fclose() Безвредность в нитях MT-Safe

СООТВЕТСТВИЕ СТАНДАРТАМ

POSIX.1-2001, POSIX.1-2008, C89, C99.

ЗАМЕЧАНИЯ

Заметим, что fclose() сбрасывает буферы только пользовательского пространства, заданные библиотекой Си. Чтобы гарантировать, что данные действительно физически сохранены на диске, буферы ядра также должны быть сохранены, например, с помощью вызова sync(2) или fsync(2).

СМОТРИТЕ ТАКЖЕ

close(2), fcloseall(3), fflush(3), fileno(3), fopen(3), setbuf(3)

2016-12-12 GNU