FCLOSE(3) | Руководство программиста Linux | FCLOSE(3) |
fclose - закрывает поток
#include <stdio.h>
int fclose(FILE *stream);
Функция fclose() сбрасывает (flushes) поток, указанный в stream (записывает все буферизированные выходные данные с помощью fflush(3)) и закрывает связанный с ним файловый дескриптор.
При успешном выполнении возвращается нулевое значение. В противном случае возвращается EOF и errno присваивается код ошибки. В любом случае, дальнейшие попытки доступа (включая ещё один вызов fclose()) к потоку приведут к неопределенному результату.
Функция 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 |