Когда проводятся операции чтения – записи в файл, существует понятие указателя текущей позиции файла. При открытии файла текущая позиция указателя находится в начале файла, значение указателя текущей позиции равно 0, далее при чтении или записи он перемещается по файлу, значение указателя текущей позиции соответствует смещению позиции от начала файла в байтах.
Функция, которая позволяет проверить достигли ли указатель текущей позиции конца файла, имеет заголовок:
int feof(FILE * stream);
параметр stream – указатель на структуру FILE, который связан с открытым файлом, возвращает не 0, если курсор находится на конце файла или 0, в противном случае.
Функции записи в файл
Следующие функции работают так же, как аналогичные функции для записи в поток stdout. Но эти функции имеют на один параметр больше, параметр stream – указатель на структуру FILE, который связан с открытым файлом. Ниже представлены заголовки функций.
Запись символа в файл:
int fputc(int c, FILE *stream);
Запись строки символов в файл:
int fputs(const char * s, FILE * stream);
Запись данных в файл в соответствии с заданным форматом (форматированный вывод):
int fprintf(FILE * stream, const char * format, …);
Рассмотрим еще одну полезную функцию записи, которая применяется, как правило, в двоичном режиме.
Запись данных в файл из оперативной памяти без преобразований:
unsigned fwrite(void * buf, unsigned size, unsigned count, FILE *stream);
параметры: buf – адрес в оперативной памяти, начиная с которого начинают записываться данные, size – размер блока данных в байтах, count – число блоков данных (при записи массива), stream – указатель на структуру FILE; возвращаемое значение – число реально записанных блоков в файл.
Функции чтения из файла
Следующие функции работают так же, как аналогичные функции для чтения из потока stdin. Эти функции также имеют на один параметр больше, параметр stream – указатель на структуру FILE, который связан с открытым файлом. Ниже представлены заголовки функций.
Чтение символа из файла:
int fgetc(FILE * stream);
Чтение строки символов из файла:
char * fgets(char * s, int n, FILE * stream);
параметр n – максимальное число читаемых символов.
Считывание данных из файла и запись их в переменные в соответствии с заданным форматом:
int fscanf(FILE * stream, const char * format, …);
Дополнительно рассмотрим функцию чтения, которая работает в двоичном режиме.
Чтение данных из файла и запись их в оперативную память без преобразований:
unsigned fread(void *buf, unsigned size, unsigned count, FILE *stream);
параметры: buf – адрес в оперативной памяти, куда записываются данные, size – размер блока данных в байтах, count – число блоков данных (при чтении массива), stream – указатель на структуру FILE; возвращаемое значение – число реально прочитанных блоков из файла.
Функции позицирования в файлах
При выполнении операций чтения - записи в файле требуется иногда перемещать указатель текущей позиции файла, например, при переходе от чтения к записи или наоборот (когда файл открыт в комбинированных режимах). Для перемещения указателя существуют специальные функции.
Функция для установки указателя текущей позиции в заданное положение:
int fseek(FILE * stream, long offset, int fromwhere);
параметры: stream – указатель на структуру FILE, offset – смещение в байтах указателя текущей позиции от позиции, заданной следующим параметром, fromwhere – возможные значения заданы константами: SEEK_SET – начало файла, SEEK_CUR – текущее положение указателя, SEEK_END – конец файла. Возвращаемое значение: 0, если функция нормально завершает свою работу, не 0 – в случае ошибки.
Функция для установки указателя текущей позиции в начало файла:
void rewind(FILE * stream);
параметр stream – указатель на структуру FILE.
Функция для получения текущего положения указателя позиции файла (смещение в байтах от начала файла):
long ftell(FILE * stream);
параметр stream – указатель на структуру FILE, функция возвращает текущее положение указателя.