Мы используем argc, чтобы посмотреть, есть ли аргумент. Любые избыточные аргументы игнорируются. Помещая в программу еще один цикл, вы могли бы использовать дополнительные аргументы - имена файлов и пропускать в цикле каждый из этих файлов по очереди.
С целью создания нового имени выходного файла мы используем функцию strcpy( )для копирования имени eddyв массив nаmе. Затем применяем функцию strcat( )для объединения этого имени с .red.
Программа требует, чтобы два файла были открыты одновременно, поэтому мы описали два указателя типа 'FILE '. Заметим, что каждый файл должен открываться и закрываться независимо от другого. Существует ограничение на количество файлов, которые вы можете держать открытыми одновременно. Оно зависит от типа системы, но чаще всего находится в пределах от 10 до 20. Можно использовать один и тот же указатель для различных файлов при условии, что они нс открываются в одно и то же время.
Мы не ограничиваемся использованием только функций getc( )и putc( )для файлов ввода-вывода. Далее мы рассмотрим некоторые другие возможности.
ВВОД-ВЫВОД ФАЙЛА: fprintf( ), fscanf( ), fgets( ) И fputs( )
Все функции ввода-вывода, которые мы использовали в предыдущих главах, имеют аналоги для ввода-вывода файла. Основное отличие состоит в том, что вам нужно использовать указатель типа FILE, чтобы сообщить новым функциям, с каким файлом им следует работать. Подобно getc( )и putc( )эти функции используются после функции fopen( ), открывающей файл, и перед fclose( ), закрывающей его.
Функции fprintf( ) и fscanf( )
Эти функции ввода-вывода работают почти как printf( )и scanf( ), но им нужен дополнительный аргумент для ссылки на сам файл. Он является первым в списке аргументов. Вот пример, иллюстрирующий обращение к этим функциям:
/* образец использования fprintf( ) и fscanf( ) */
#include
main( )
{
FILE *fi;
int age;
fi = fopen("sam", "r"); /* считывание */
fscanf(fi, "%d", &age); /* fi указывает на sam */
fclose(fi);
fi = fopen("data", "a"); /* дополнение "/
fprintf(fi, "sam is %d. \n", age); /* fi указывает на data */
fclose(fi);
}
Заметим, что можно было использовать fiдля двух различных файлов, потому что мы закрыли первый файл, прежде чем открыть второй.
В отличие от getc( )и putc( )эти две функции получают указатель типа FILEв качестве первого аргумента. Две другие, описанные ниже, получают его в качестве последнего аргумента.
Эта функция имеет три аргумента, в то время как gets( )имеет один. Вот пример ее использования:
/* считывает файл строка за строкой */
#include
#define MAXLIN 80
main( )
{
FILE *f1;
char *string [MAXLIN];
f1 = fopen("story", "r");
while(fgets(string, MAXLIN, f1) != NULL)
puts(string);
}
Первый из трех аргументов функции fgets( )является указателем на местоположение считываемой строки. Мы располагаем вводимую информацию в символьный массив string.
Второй аргумент содержит предельную длину считываемой строки. Функция прекращает работу после считывания символа новой строки или после считывания символов общим числом MAXLIN - 1(в зависимости от того, что произойдет раньше). В любом случае нуль-символ ( '\0') добавляется в самый конец строки.
Третий аргумент указывает, конечно, на файл, который будет читаться.
Разница между gets( )и fgets( )заключается в том, что gets( )заменяет символ новой строки на '\0', в то время как fgets( )сохраняет символ новой строки.
Подобно gets( )функция fgets( )возвращает значение NULL, если встречает символ EOF. Это позволяет вам проверить, как мы и сделали, достигли ли вы конца файла.
Эта функция очень похожа на puts( ). Оператор
fputs(" Вы были правы.", fileptr);
передает строку "Вы были правы." В файл, на который ссылается указатель fileptrтипа FILE. Конечно, сначала нужно открыть файл при помощи функции fopen( ). В самом общем виде это выглядит так
status = fputs(yказатель строки, указатель файла);
где statusявляется целым числом, которое устанавливается в EOF, если fputs( )встречает EOFили ошибку.
Подобно puts( )эта функция не ставит завершающий символ '\0'в конец копируемой строки. В отличие от puts()функция fputs( )не добавляет символ новой строки в ее вывод.
Читать дальше