Описание функций Си



         

Freopen



     freopen

Функция Связывет с потоком новый файл.

Синтаксис #include

FILE * freopen(char * filename, char * mode, FILE *stream);

Файл, содержащий stdio.h прототип

Описание Функция freopen замещает указанным файлом откры- тый поток stream. Функция freopen закрывает файл, связанный со stream, независимо от откраваемого файла. Ее можно использовать для изменения пото- ков, связанных с stdin, stdout или stderr.

Строка mode, используемая в функции freopen, мо- жет принимать следующие значения:

r - открытие файла только для чтения;

w - создание файла для записи;

а - присоединение; открытие для записи в конец файла или создание для записи, если файл не существует;

r+ - открытие существующего файла для обновления (чтения и записи);

w+ - создание нового файла для изменения;

a+ - открытие для присоединения; открытие (или создание, если файл не существует) для об- новления в конец файла.

Если данный файл открывается или создается в тек- стовом режиме, вы можете приписать символ t к значению параметра mode (rt, w+t, и т.д.); анало- гично, для спецификации бинарного режима вы може- те к значению параметра mode добавить символ b (wb,a+b, и т.д.). Если в параметре mode отсутст- вуют символы t или b, режим будет определяться глобальной переменной _fmode. Если переменная _fmode имеет значение O_BINARY, файлы будут отк- рываться в бинарном режиме, иначе, если _fmode имеет значение O_TEXT, файлы открываются в текс- товом режиме. Данные константы O_... определены в файле fcntl.h.

При открытии файла в режиме обновления (UPDATE), над результирующим потоком stream могут быть вы- полнены как операции ввода, так и вывода. Тем не менее вывод не может следовать непосредственно за вводом без вмешательства функций fseek или rewind, а также ввод без применения функций fseek, rewind не может непосредственно следовать за выводом или вводом, который встречает конец файла (EOF).

Возвращаемое При успешном завершении, freopen возвращает значение указатель на открытый поток stream. В случае ошибки, функция возвращает ноль (NULL).

Переносимость freopen поддерживаeтся на системах UNIX и совместима со стандартом ANSI C.

Смотрите также

Пример:

#include

int main(void) { /* перенаправить стандартный вывод в файл */ if(freopen("OUTPUT.FIL","w",stdout) == NULL) fprintf(stderr,"Ошибка перенаправления потока\n"); /* этот вывод будет осуществляться в файл */ printf("этот вывод будет осуществляться в файл\n"); /* закрыть стандартный вывод */ close(stdout); return 0; }




Содержание  Назад  Вперед