Навигация
Главная
Поиск
Форум
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
Создание отчето... 65467
Модуль Forms 65224
Пример работы с... 64772
ТЕХНОЛОГИИ ДОСТ... 61928
Имитационное мо... 57799
Реклама
Сейчас на сайте
Гостей: 6
На сайте нет зарегистрированных пользователей

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

Метод половинного деления для нахождения корня уровнения на Turbo Pascal...
Моделирование автовокзала + Отчет + Блок схема
Лабораторная работа по динамическим спискам на Turbo Pascal (удаление ду...

Реклама



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

ПОДПИСЫВАЙСЯ на канал о программировании
Процедура проверки состояния очереди
Через некоторое время диспетчер STREAMS выбирает очередь А и вызывает для нее процедуру service.

Эта процедура запрашивает сообщения из очереди в порядке FIFO. После обработки сообщений она вызывает canput() для проверки готовности следующей очереди, поддерживающей управление потоком, принять сообщение. Процедура canput() просматривает указатели q_next до тех пор, пока не найдет нужную очередь. В рассматриваемом примере это В.

Также на сайте era-tourisma.ru можно узнать много интересного на тему http://era-tourisma.ru/. Что означает вообще тема сплавы Карелии - про это написано на сайте era-tourisma.ru. Спасибо сайту за информацию.


Затем процедура проверяет состояние очереди и возвращает TRUE, если очередь способна принять дополнительные сообщения, или FALSE, когда очередь переполнена. Процедура service очереди А в этих двух случаях будет вести себя по-разному (см. листинг 17.1).
Если canput() возвращает TRUE, очередь А вызывает процедуру putnext(), которая отправляет сообщение в очередь Б. Эта очередь не поддерживает управление потоком, поэтому производит безотлагательную обработку сообщения и передает его очереди В (для которой раньше была сделана проверка на готовность принять еще одно сообщение).
Когда canput() возвращает FALSE, очередь А вызывает процедуру putbq() для возврата сообщения в его очередь сообщений. Процедура service возвратится без помещения себя на обслуживание.



Через некоторый промежуток времени очередь В обработает свои сообщения, тем самым добавив свободного места до значения большего, чем нижняя граница. Если в очереди появляется свободное место, подсистема STREAMS автоматически проверяет, не заблокирована ли предыдущая очередь, поддерживающая управление потоком (в нашем примере очередь А). Если это так, подсистема отправит ее на обслуживание. Указанная операция получила название восстановления доступности (back-enabling) очереди.
Опубликовал katy June 24 2015 23:17:55 · 0 Комментариев · 1457 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Пример работы с б...
Технология .Net в VB
AddPage [Исходник...
SendSMS для PHP-F...
PHP 5. Полное рук...
C++ Builder 6 СПР...
Распознавание иде...
PDPcheck
Prolog Interprete...
Архив программ
IconCut [Исходник...
SODA [Исходник на...
Карта сайта
Базы данных в Инт...
Пример работы с ф...
Дешифратор содерж...
Панель Наша Кнопка
Алгоритм DES шифр...
C++ Builder в за...
Программирование ...

Топ загрузок
Приложение Клие... 100470
Delphi 7 Enterp... 87111
Converter AMR<-... 20078
GPSS World Stud... 12866
Borland C++Buil... 11849
Borland Delphi ... 8609
Turbo Pascal fo... 7039
Visual Studio 2... 4999
Калькулятор [Ис... 4806
FreeSMS v1.3.1 3542
Случайные статьи
Вулкан 777
Дополнительная лит...
Вскрытие корпуса
Синтаксис SQL-запроса
удаленного офиса с...
Как правильно иска...
Определение полимо...
Азартные игры в Ин...
Добавление квалифи...
Печать русских бук...
Файл главной компо...
Использование спис...
Просмотр курсора н...
Безопасность
Программируемая за...
Вложенные классы и...
Деструкторы в язы...
Пробуйте щелкнуть ...
Женская психология
Ключевые факты об ...
Анимационные прогр...
Примеры программир...
Самоуправление или...
Протокол VRRP и ма...
5.5. РЕШЕНИЕ: ОБЪЯ...
Статистика



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


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