stdio(3) библиотека функций стандартного ввода-вывода

ОБЗОР

#include <stdio.h>

FILE *stdin;
FILE *stdout;
FILE *stderr;

ОПИСАНИЕ

Библиотеки стандартного ввода-вывода предоставляют простой и эффективный интерфейс буферизируемого потока ввода-вывода. Ввод и вывод представляется логическим потоком данных, а физические характеристики ввода-вывода скрываются. Далее приводится список функций и макросов; более подробная информация находится в соответствующих страницах.

Поток соотносится с внешним файлом (который также может быть физическим устройством) при открытии файла. Такое открытие может вызвать создание нового файла. Создание существующего файла вызовет потерю его содержимого. Если для файла поддерживаются запросы позиционирования (например для файла на диске, а не терминал), то индикатор позиции в файле, соответствующий потоку, устанавливается в начало файла (нулевой байт), если только файл не открыт в режиме добавления. Если используется режим добавления, то не определено, будет ли индикатор позиции в файле будет указывать на конец файла. Индикатор позиции изменяется при последующих запросах чтения, записи и изменения индикатора. Все операции ввода осуществляются так, как если бы все символы последовательно считывались вызовом функции fgetc(3); а вывод осуществляется, как если бы все символы последовательно записывались вызовом функции fputc(3).

Соотношение потока с файлом прекращается при закрытии файла. Перед прекращением потоки вывода очищаются (flushed) (содержимое незаписанного буфера передаётся в системное окружение). Значение указателя на объект FILE после закрытия файла становится неопределённым (мусорным).

Впоследствии файл может быть открыт ещё раз той же самой или другой программой, а его содержание может быть восстановлено или изменено (если можно перейти в его начало). Если основная функция завершает работу и возвращает значения своему родителю или если вызывается функция exit(3), то перед закрытием программы закрываются все открытые файлы (и, следовательно, очищаются все потоки вывода). Другие методы закрытия программ, например, abort(3), не всегда приводят к корректному закрытию файлов.

При запуске программы предопределяются три текстовых потока, которые не следует открывать явно: стандартный ввод (standard input) (для чтения условного ввода), стандартный вывод (standard output) (для записи условного вывода) и стандартный поток ошибок (standard error) (для вывода диагностики). Сокращённые названия потоков: stdin, stdout и stderr. При открытии, стандартный поток ошибок буферизируется не полностью; стандартные потоки ввода и вывода полностью буферизируются только при условии, что они не ссылаются на какое-либо интерактивное устройство.

Потоки вывода, ссылающиеся на устройства терминала, по умолчанию буферизируются построчно; ожидающие в таких потоках данные записываются автоматически всякий раз при чтении из потока ввода, ссылающегося на терминал. В случаях, когда после вывода на терминал части строки объём производимых вычислений велик, необходимо выполнять fflush(3), чтобы появилась часть строки до вычислений.

Библиотека stdio является частью библиотеки libc, а функции автоматически загружаются компиляторами cc(1) и pc(1) по мере надобности. В разделе СИНТАКСИС справочных страниц указано какие файлы заголовков необходимо использовать, как выглядят объявления функций и какие внешние переменные представляют интерес для работы.

В списке далее перечислены макросы; эти имена не могут быть использованы повторно без предварительного удаления их определений с помощью #undef: BUFSIZ, EOF, FILENAME_MAX, FOPEN_MAX, L_cuserid, L_ctermid, L_tmpnam, NULL, SEEK_END, SEEK_SET, SEEK_CUR, TMP_MAX, clearerr, feof, ferror, fileno, getc, getchar, putc, putchar, stderr, stdin, stdout. Для feof, ferror, clearerr, fileno, getc, getchar, putc, и putchar существуют версии в виде функций, которые используются если определения макросов были удалены явно.

Список функций

ФункцияОписание

clearerrпроверяет и сбрасывает состояние потока
fcloseзакрывает поток
fdopenфункции открытия потока
feofпроверяет и сбрасывает состояние потока
ferrorпроверяет и сбрасывает состояние потока
fflushсбрасывает данные потока
fgetcсчитывает следующий символ или слово из потока ввода
fgetposсчитывает позицию в потоке
fgetsсчитывает строку из потока
filenoвозвращает целочисленный дескриптор аргумента потока
fopenфункции открытия потока
fprintfвывод по формату
fpurgeсбрасывает данные потока
fputcвыводит символ и слово в поток
fputsвыводит строку в поток
freadсчитывает двоичные данные из потока ввода-вывода
freopenфункции открытия потока
fscanfформатирует ввод
fseekустанавливает позицию в потоке
fsetposустанавливает позицию в потоке
ftellустанавливает позицию в потоке
fwriteзаписывает двоичные данные потока ввода-вывода
getcсчитывает следующий символ или слово из потока ввода
getcharсчитывает следующий символ или слово из потока ввода
getsсчитывает строку из потока
getwсчитывает следующий символ или слово из потока ввода
mktempсоздаёт имя временного файла (уникальное)
perrorсистемные сообщения об ошибках
printfвывод по формату
putcвыводит символ или слово в поток
putcharвыводит символ и слово в поток
putsвыводит строку в поток
putwвыводит символ и слово в поток
removeудаляет запись из каталога
rewindустанавливает позицию в потоке
scanfформатирует ввод
setbufоперации буферизации потока
setbufferоперации буферизации потока
setlinebufоперации буферизации потока
setvbufоперации буферизации потока
sprintfвывод по формату
sscanfформатирует ввод
strerrorсистемные сообщения об ошибках
sys_errlistсистемные сообщения об ошибках
sys_nerrсистемные сообщения об ошибках
tempnamпроцедуры с временными файлами
tmpfileпроцедуры с временными файлами
tmpnamпроцедуры с временными файлами
ungetcвозвращает символ в поток ввода
vfprintfвывод по формату
vfscanfформатирует ввод
vprintfвывод по формату
vscanfформатирует ввод
vsprintfвывод по формату
vsscanfформатирует ввод

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

Библиотека stdio соответствует C89.