C++ C++ C# C# ASP.NET Security ASP.NET Security ASM ASM Скачать Скачать Поиск Поиск Хостинг Хостинг  
  Программа для работы с LPT портом...
Язык: .NET — ©Alexey...
  "ASP.NET Atlas" – AJAX в исполнении Micro...
Язык: .NET — ©legigor@mail.ru...
  "Невытесняющая" Многопоточность...
Язык: C/C++ — ©...
  Update World C++: Сборник GPL QT исходников
  Весь сайт целиком можно загрузить по ссылкам из раздела Скачать

 setbuf / s / Библиотечн. функции Borland C++

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;
}