table of contents
fflush(3) | Library Functions Manual | fflush(3) |
ИМЯ¶
fflush - сбрасывает поток
LIBRARY¶
Standard C library (libc, -lc)
СИНТАКСИС¶
#include <stdio.h>
int fflush(FILE *_Nullable stream);
ОПИСАНИЕ¶
Для потоков вывода функция fflush() принудительно записывает все буферизированные в пользовательском пространстве данные в устройство вывода данных или корректирует stream посредством определённой для него функции записи.
Для потоков ввода, связанных с файлами, в которых возможно позиционирование (например, дисковые файлы, но не каналы или терминалы), функция fflush() отбрасывает все буферизированные данные, которые были получены из соответствующего файла, но не обработаны приложением.
При этом поток остается открытым.
Если аргумент stream равен NULL, то fflush() сбрасывает данные всех открытых потоков вывода.
Неблокирующий аналог смотрите в unlocked_stdio(3).
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ¶
При успешном выполнении возвращается нулевое значение. В противном случае возвращается EOF и errno присваивается код ошибки.
ОШИБКИ¶
- EBADF
- Поток stream не открыт или не открыт для записи.
Функция fflush() может завершиться с ошибкой и присвоить errno любое значение из определённых для write(2).
АТРИБУТЫ¶
Описание терминов данного раздела смотрите в attributes(7).
Интерфейс | Атрибут | Значение |
fflush() | Безвредность в нитях | MT-Safe |
СТАНДАРТЫ¶
C11, POSIX.1-2008.
ИСТОРИЯ¶
C89, POSIX.1-2001, POSIX.1-2008.
В POSIX.1-2001 не определено поведение для сброса потоков ввода, но но это описано в POSIX.1-2008.
ПРИМЕЧАНИЯ¶
Заметим, что fflush() сбрасывает буферы только пользовательского пространства, заданные библиотекой Си. Чтобы гарантировать, что данные действительно физически сохранены на диске, буферы ядра также должны быть сохранены, например, с помощью вызова sync(2) или fsync(2).
СМОТРИТЕ ТАКЖЕ¶
fsync(2), sync(2), write(2), fclose(3), fileno(3), fopen(3), fpurge(3), setbuf(3), unlocked_stdio(3)
ПЕРЕВОД¶
Русский перевод этой страницы руководства разработал Azamat Hackimov <azamat.hackimov@gmail.com>, Dmitry Bolkhovskikh <d20052005@yandex.ru>, Yuri Kozlov <yuray@komyakino.ru> и Иван Павлов <pavia00@gmail.com>
Этот перевод является свободной программной документацией; он распространяется на условиях общедоступной лицензии GNU (GNU General Public License - GPL, https://www.gnu.org/licenses/gpl-3.0.html версии 3 или более поздней) в отношении авторского права, но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ.
Если вы обнаружите какие-либо ошибки в переводе этой страницы руководства, пожалуйста, сообщите об этом разработчику по его адресу электронной почты или по адресу списка рассылки русских переводчиков.
2 мая 2024 г. | Linux man-pages (unreleased) |