Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Создание отчето... 63566
Модуль Forms 63392
ТЕХНОЛОГИИ ДОСТ... 60173
Пример работы с... 59268
Имитационное мо... 55614
Реклама
Сейчас на сайте
Гостей: 12
На сайте нет зарегистрированных пользователей

Пользователей: 13,078
новичок: codepro
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Моделирование работы аэропорта на GPSS + Пояснительная записка
Моделирование круглосуточного интернет кафе на GPSS + Отчет
Моделирование вычислительного центра на GPSS + Отчет + Блок схема

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Принципы организации потоков
С одной стороны, потоки можно разделить на входные и выходные: из входного потока программа данные читает (извлекает, вводит), в выходной поток — пишет (помещает, выводит). С другой стороны, потоки бывают форматируемые и нефор-матируемые, буферизуемые и небуферизуемые, широкие (wide) и узкие (narrow). Широкие потоки оперируют широкими символами wchar_t (см. п. п. С.2.2.1 в [1]), а узкие — обычными символами char.
Форматируемость означает, что при операциях ввода-вывода выполняется преобразование информации. Так как поток — это последовательность символов, при вводе, как правило, выполняется преобразование данных из символьного вида в двоичное представление, а при выводе — наоборот. Форматирование, например, всегда выполняется для стандартных потоков.
Буферизация позволяет еще больше «развязать» программы и устройства. Если поток буферизован, то вывод выполняется не на устройство, а в специально выделяемую область памяти — буфер. Заполненный буфер выводится на устройство, как правило, без непосредственного указания в программе. Однако программа может потребовать вывести неполный буфер. При вводе программа тоже имеет дело с буфером, а не с устройством, то есть данные в программу попадают из буфера. Буфер обычно заполняется при выполнении первой операции ввода, но специально программировать это не требуется. Обычно буферизация реализуется по умолчанию, но в библиотеках есть средства, позволяющие управлять назначением буферов. Схема ввода-вывода с буферизацией изображена на рис. 14.1.

Внешний источник информации




Рис. 14.1. Буферизация ввода-вывода
Библиотека предоставляет программисту ряд классов (см. листинг 14.1), которые реализуют три вида потоков: стандартные, строковые и файловые потоки. Стандартные потоки бывают только однонаправленными: либо информация только читается из потока, либо — только пишется в поток. А вот файловые потоки могут быть и двунаправленными: из потока можно вводить информацию и в тот же поток — выводить. И это естественно, так как файловые потоки обычно связываются с файлами на диске. Объектно-ориентированные строковые потоки позволяют работать и с символьными массивами, и со строками типа string. В отличие от потоков библиотеки <cstdi о>, эти потоки также могут быть двунаправленными.
Стандартные потоки обозначаются именами, определенными в стандарте, которые нельзя использовать в другом смысле. Эти имена «привязаны» к стандартным устройствам: клавиатуре и экрану, хотя есть возможности перенаправить стандартные потоки на другие устройства. Кроме того, стандартные потоки — форматируемые, среди них есть как буферизуемые, так и не буферизуемые.
Опубликовал Kest February 20 2014 01:38:55 · 0 Комментариев · 3336 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
C# 2005 и платфор...
Применение фильтр...
Delphi на примерах
Игра PackMan
Конвертирование и...
Программирование ...
CoolHints2k
BIOS
mmmJlabel
Добавление басса ...
Пример создания W...
Введение в станда...
WAP версия сайта
Формирование отче...
CwstatusBar
Мод "register.php...
Preview
PHP: настольная к...
Иллюстрированный ...
DCMintry

Топ загрузок
Приложение Клие... 100444
Delphi 7 Enterp... 85615
Converter AMR<-... 20065
GPSS World Stud... 12472
Borland C++Buil... 11525
Borland Delphi ... 8480
Turbo Pascal fo... 7020
Visual Studio 2... 4987
Калькулятор [Ис... 4726
FreeSMS v1.3.1 3533
Случайные статьи
client)
Линии выноски для ...
Применение подсете...
Изменение направле...
Адресаты инфографики
Установка палагино...
Вот пример сеанса ...
Логическое «И»
Простота
Работа с ячейками
Устранение дребезг...
В текстовом файле ...
10 Заблуждений при...
Заголовок приема
Порты исключительн...
Примеры кода
Моделирование элек...
Потоки и скорости
Программа вычитает...
Занятие 3. Распрос...
Х \== Y
Слоты 777
Что такое процессо...
Алгоритм “быстрой ...
В какую объединенн...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?