Чтение онлайн

ЖАНРЫ

Основы программирования в Linux
Шрифт:

Далее приведена синтаксическая запись функции:

#include <stdio.h>

size_t fread(void *ptr, size_t size, size_t nitems, FILE *stream);

Как и в других функциях стандартного ввода/вывода, записывающих данные в буфер, выделять место для данных и проверять ошибки должен программист. См. также функции

ferror
и
feof
далее в этой главе.

fwrite

Интерфейс библиотечной функции

fwrite
аналогичен интерфейсу функции
fread
. Она принимает записи данных из заданного буфера данных и записывает их в поток вывода. Функция возвращает
количество успешно записанных записей.

Далее приведена синтаксическая запись функции:

#include <stdio.h>

size_t fwrite(const void *ptr, size_t size, size_t nitems, FILE *stream);

Примечание

Имейте в виду, что функции

fread
и
fwrite
не рекомендуется применять со структурированными данными. Частично проблема заключается в том, что файлы, записанные функцией fwrite, могут быть непереносимыми между машинами с разной архитектурой.

fclose

Библиотечная функция

fclose
закрывает заданный поток stream, заставляя записать все незаписанные данные. Важно применять функцию
fclose
, поскольку библиотека stdio будет использовать буфер для данных. Если программе нужна уверенность в том, что все данные записаны, следует вызвать
fclose
. Имейте в виду, что функция
fclose
вызывается автоматически для всех файловых потоков, которые все еще открыты к моменту нормального завершения программы, но при этом у вас, конечно же, не будет возможности проверить ошибки, о которых сообщает
fclose
.

Далее приведена синтаксическая запись функции:

#include <stdio.h>

int fclose(FILE* stream);

fflush

Библиотечная функция

fflush
вызывает немедленную запись всех данных файлового потока, ждущих выполнения операции записи. Вы можете применять ее, например, чтобы убедиться, что интерактивное приглашение отправлено на терминал до того, как делается попытка считать ответ. Эта функция также полезна, если вы хотите, прежде чем продолжить выполнение, убедиться в том, что важные данные помещены на диск. Ее можно применять в некоторых случаях при отладке программы, чтобы быть уверенным в том, что программа действительно записывает данные, а не зависла. При вызове функции
fclose
выполняется неявная операция
fflush
, поэтому перед
fclose
не нужно вызывать функцию
fflush

Далее приведена синтаксическая запись функции:

#include <stdio.h>

int fflush(FILE *stream);

fseek

Функция

fseek
— это эквивалент для файлового потока системного вызова
lseek
. Она задает в
stream
позицию для следующей операции чтения этого потока или записи в него. Значения и смысл параметров
offset
и
whence
такие же, как у ранее описанных одноименных параметров вызова
lseek
. Но там, где
lseek
возвращает
off_t
, функция
fseek
возвращает целое число: 0, если выполнилась успешно, и -1 при аварийном завершении с ошибкой, указанной в переменной
errno
. Какое поле деятельности для стандартизации!

Далее приведена синтаксическая запись функции:

#include <stdio.h>

int fseek(FILE *stream, long int offset, int whence);

fgetc, getc и getchar

Функция

fgetc
возвращает из файлового потока следующий байт как символ. Когда она достигает конца файла или возникает ошибка, функция возвращает
EOF
. Для того чтобы различить эти два случая, следует применять функции
ferror
или
feof
.

Далее приведена синтаксическая запись функций:

#include <stdio.h>

int fgetc(FILE *stream);

int getc(FILE *stream);

int getchar;

Функция

getc
эквивалентна
fgetc
за исключением того, что может быть реализована как макрос. В этом случае аргумент
stream
может определяться несколько раз, поэтому он лишен побочных эффектов (например, не затронет переменные). К тому же вы не можете гарантировать возможности применения адреса
getc
как указателя функции.

Функция

getchar
эквивалентна вызову функции
getc(stdin)
и читает следующий символ из стандартного ввода.

fputc, putc и putchar

Функция

fputc
записывает символ в файловый поток вывода. Она возвращает записанное значение или
EOF
в случае аварийного завершения.

#include <stdio.h>

int fputc(int с, FILE *stream); int putc(int c, FILE *stream); int putchar(int c);

Как и в случае функций

fgetc/getc
, функция
putc
— эквивалент
fputc
, но может быть реализована как макрос.

Функция

putchar
— то же самое, что вызов
putc(с, stdout)
, записывающий один символ в стандартный вывод. Имейте в виду, что функция
putchar
принимает, а функция
getchar
возвращает символы как данные типа
int
, а не
char
. Это позволяет индикатору конца файла (
EOF
) принимать значение -1, лежащее вне диапазона кодов символов.

fgets и gets

Функция

fgets
читает строку из файла ввода
stream
.

#include <stdio.h>

char *fgets(char *s, int n, FILE *stream);

char *gets(char *s);

Функция

fgets
пишет символы в строку, заданную указателем
s
, до тех пор, пока не встретится новая строка, либо не будет передано
n-1
символов, либо не будет достигнут конец файла. Любая встретившаяся новая строка передается в строку, принимающую символы, и добавляется завершающий нулевой байт
\0
. Любой вызов передает максимум
n-1
символов, т.к. должен быть вставлен нулевой байт, обозначающий конец строки и увеличивающий общее количество до n байтов.

При успешном завершении функция

fgets
возвращает указатель на строку
s
. Если поток указывает на конец файла, она устанавливает индикатор
EOF
для потока и возвращает пустой указатель. Если возникает ошибка чтения,
fgets
возвращает пустой указатель и устанавливает значение переменной
errno
, соответствующее типу ошибки.

Функция

gets
аналогична
fgets
за исключением того, что она читает из стандартного ввода и отбрасывает любые обнаруженные обозначения новой строки. Функция добавляет завершающий нулевой байт в принимающую строку.

Поделиться с друзьями: