Справочник функций

Ваш аккаунт

Войти через: 
Забыли пароль?
Регистрация
Информацию о новых материалах можно получать и без регистрации:

Почтовая рассылка

Подписчиков: -1
Последний выпуск: 19.06.2015

setbuf

setbuf


Функция            Назначает буфер для потока stream.

Синтаксис          #include <stdio.h>
                   void setbuf(FILE *stream, char *buf);

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

Описание           Функция setbuf     выделяет    буфер    buf    для
                   использования в операциях  ввода/вывода  -  вместо
                   автоматически   выделяемого   буфера.   Он   будет
                   использоваться только после того, как данный поток
                   stream будет открыт.

                   При использовании функции  setbuf,  если  параметр
                   buf = NULL,  ввод/вывод производится без буфера; в
                   противном случае буфер используется.

                   Буфер должен быть длиной  BUFSIZE  байтов  (данная
                   константа определяется в файле stdio.h).

                   Стандартный ввод   и   вывод  stdin  и  stdout  не
                   используют   буферов,    если    они    не    были
                   переназначены;  в  противном случае,  ввод и вывод
                   производиться с буферизацией.

                   unbuffered (небуферизованный ввод/вывод) означает,
                   что   символы,  записываемые  в  поток,  поступают
                   непосредственно в файл или  на  устройство;  в  то
                   время  как  buffered  (буферизованный  ввод/вывод)
                   означает,  что  символы  накапливаются   и   затем
                   записываются, как блок.

                   Функция setbuf  может  привести  к  непредвиденным
                   результатам,  если  она  вызывается   для   потока
                   stream,  причем не следует немедленно за операцией
                   открытия или вызовом функции fseek.  Вызов функции
                   setbuf после того,  как поток stream обработан без
                   буферов, разрешен, и не вызовет ошибок.

                   Наиболее распространенной причиной ошибки является
                   размещение    буфера,    в    качестве   automatiс
                   (локальной) переменной  и  затем  попытка  закрыть
                   файл до выхода из функции,  в которой был объявлен
                   буфер.

Возвращаемое       Нет.
значение

Переносимость      Функция поддерживаются на системах UNIX и стан-
                   дартом ANSI C.

Смотрите также     fflush, fopen, fseek, setvbuf.

Пример:

#include<stdio.h>

/* BUFSIZE определено в stdio.h */
char buf[BUFSIZE];

int main(void)
{
   int i;
   /* подключить буфер к стандартному потоку */
   setbuf(stdout,buf);
   /* поместить в буфер символы */
   puts("Это тест буферизованного вывода.\n");
   puts("Этот вывод осуществляется в buf\n");
   puts("и вы ничего не увидите, пока буффер не заполнится\n");
   puts("или вы не сбросите его.\n");
   /* сбросить поток */
   fflush(stdout);
   return 0;
}

Оставить комментарий

Комментарий:
можно использовать BB-коды
Максимальная длина комментария - 4000 символов.
 
Реклама на сайте | Обмен ссылками | Ссылки | Экспорт (RSS) | Контакты
Добавить статью | Добавить исходник | Добавить хостинг-провайдера | Добавить сайт в каталог