Далее приведена синтаксическая запись функции:
#include
size_t fread(void *ptr, size_t size, size_t nitems, FILE *stream);
Как и в других функциях стандартного ввода/вывода, записывающих данные в буфер, выделять место для данных и проверять ошибки должен программист. См. также функции ferrorи feofдалее в этой главе.
Интерфейс библиотечной функции fwriteаналогичен интерфейсу функции fread. Она принимает записи данных из заданного буфера данных и записывает их в поток вывода. Функция возвращает количество успешно записанных записей.
Далее приведена синтаксическая запись функции:
#include
size_t fwrite(const void *ptr, size_t size, size_t nitems, FILE *stream);
Примечание
Имейте в виду, что функции freadи fwriteне рекомендуется применять со структурированными данными. Частично проблема заключается в том, что файлы, записанные функцией fwrite, могут быть непереносимыми между машинами с разной архитектурой.
Библиотечная функция fcloseзакрывает заданный поток stream, заставляя записать все незаписанные данные. Важно применять функцию fclose, поскольку библиотека stdio будет использовать буфер для данных. Если программе нужна уверенность в том, что все данные записаны, следует вызвать fclose. Имейте в виду, что функция fcloseвызывается автоматически для всех файловых потоков, которые все еще открыты к моменту нормального завершения программы, но при этом у вас, конечно же, не будет возможности проверить ошибки, о которых сообщает fclose.
Далее приведена синтаксическая запись функции:
#include
int fclose(FILE* stream);
Библиотечная функция fflushвызывает немедленную запись всех данных файлового потока, ждущих выполнения операции записи. Вы можете применять ее, например, чтобы убедиться, что интерактивное приглашение отправлено на терминал до того, как делается попытка считать ответ. Эта функция также полезна, если вы хотите, прежде чем продолжить выполнение, убедиться в том, что важные данные помещены на диск. Ее можно применять в некоторых случаях при отладке программы, чтобы быть уверенным в том, что программа действительно записывает данные, а не зависла. При вызове функции fcloseвыполняется неявная операция fflush, поэтому перед fcloseне нужно вызывать функцию fflush.
Далее приведена синтаксическая запись функции:
#include
int fflush(FILE *stream);
Функция fseek— это эквивалент для файлового потока системного вызова lseek. Она задает в streamпозицию для следующей операции чтения этого потока или записи в него. Значения и смысл параметров offsetи whenceтакие же, как у ранее описанных одноименных параметров вызова lseek. Но там, где lseekвозвращает off_t, функция fseekвозвращает целое число: 0, если выполнилась успешно, и -1 при аварийном завершении с ошибкой, указанной в переменной errno. Какое поле деятельности для стандартизации!
Далее приведена синтаксическая запись функции:
#include
int fseek(FILE *stream, long int offset, int whence);
Функция fgetcвозвращает из файлового потока следующий байт как символ. Когда она достигает конца файла или возникает ошибка, функция возвращает EOF. Для того чтобы различить эти два случая, следует применять функции ferrorили feof.
Далее приведена синтаксическая запись функций:
#include
int fgetc(FILE *stream);
int getc(FILE *stream);
int getchar();
Функция getcэквивалентна fgetcза исключением того, что может быть реализована как макрос. В этом случае аргумент streamможет определяться несколько раз, поэтому он лишен побочных эффектов (например, не затронет переменные). К тому же вы не можете гарантировать возможности применения адреса getcкак указателя функции.
Функция getcharэквивалентна вызову функции getc(stdin)и читает следующий символ из стандартного ввода.
Функция fputcзаписывает символ в файловый поток вывода. Она возвращает записанное значение или EOFв случае аварийного завершения.
#include
int fputc(int с, FILE *stream); int putc(int c, FILE *stream); int putchar(int c);
Читать дальше