Все о моделировании в Компас-3D LT
   Главная Статьи Файлы Форум Ссылки Категории новостей
April 27 2024 17:34:55   
Навигация
Главная
Статьи
Файлы
FAQ
Форум
Ссылки
Категории новостей
Обратная связь
Фото галерея
Поиск
Разное
Карта Сайта
Популярные статьи
Что необходимо ... 65535
4.12.1 Професси... 32811
Учимся удалять!... 31915
Примеры, синони... 23301
Просмотр готовы... 22528
Декартовы коорд... 22058
FAST (методика ... 21346
содержание - се... 20567
Просмотр готовы... 19170
Работа с инстру... 14631
Сейчас на сайте
Гостей: 1
На сайте нет зарегистрированных пользователей

Пользователей: 9,955
новичок: Logyattella
Друзья сайта
Ramblers Top100
Рейтинг@Mail.ru

Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ по Delphi
Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog
12.3.3.2 Wait
многопроцессорная версия алгоритма wait
{
для (;;) { /* цикл */
перебор всех процессов-потомков:
if (потомок находится в состоянии "прекращения существования") return ;
P(zombie_semaphore); /* начальное значение — 0 */
}
}
Рисунок 12.15. Многопроцессорная версия алгоритма wait
Из главы 7 мы уже знаем о том, что во время выполнения системной функции wait процесс приостанавливает свою работу до момента завершения выполнения своего потомка. В многопроцессорной системе перед процессом встает задача не упустить при выполнении алгоритма wait потомка, прекратившего существование с помощью функции exit; если, например, в то время, пока на одном процессоре процесс-родитель запускает функцию wait, на другом процессоре его потомок завершил свою работу, родителю нет необходимости приостанавливать свое выполнение в ожидании завершения второго потомка. В каждой записи таблицы процессов имеется семафор, именуемый zombie_semaphore и имеющий в начале нулевое значение. Этот семафор используется при организации взаимодействия wait/exit (Рисунок 12.15). Когда потомок завершает работу, он выполняет над семафором своего родителя операцию V, выводя родителя из состояния приостанова, если тот перешел в него во время исполнения функции wait. Если потомок завершился раньше, чем родитель запустил функцию wait, этот факт будет обнаружен родителем, который тут же выйдет из состояния ожидания. Если оба процесса исполняют функции exit и wait параллельно, но потомок исполняет функцию exit уже после того, как родитель проверил его статус, операция V, выполненная потомком, воспрепятствует переходу родителя в состояние приостанова. В худшем случае процесс-родитель просто повторяет цикл лишний раз.
Комментарии
Нет комментариев.
Добавить комментарий
Пожалуйста залогиньтесь для добавления комментария.
Рейтинги
Рейтинг доступен только для пользователей.

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

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

Пароль



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

Забыли пароль?
Запросите новый здесь.
Случайные статьи
Импульсно-кодовая ...
4.2 СТРУКТУРА ФАЙ...
2.4 УПРАВЛЕНИЕ СИС...
Какова дальность р...
Включение приемника
4. Продукции типа...
4.7 ВЫДЕЛЕНИЕ ДИС...
3.3. Группы ключе...
Цена до 250 долларов
12.3.3.4 Фиктивные...
Присвоение наимено...
Известные объекты
Глава 5. Что такое...
8.4. Управление пр...
Карты в руки!
Инструмент Отрезок...
Разъем последовате...
6. Программные про...
6.5.4 Изменение ра...
Глава 2. Cистема п...
2.2.2.3 Переходы и...
12.3.2 Реализация ...
Теоретические опас...
Вариант 2.
7.3.1. Концепции о...
Глава 15. GPS-сист...
5.18 СОПРОВОЖДЕНИЕ...
2.4.2 Логическое к...
2.4.2 Логическое к...
Вариант 3.
1.2 Логическая т...
Какие же цели прес...
Глава 5. Как уста...
3. Матричная струк...
7.4 ОЖИДАНИЕ ЗАВЕР...
6.5.6 Освобождение...
5.4. Заключение
Частотная и фазова...
Одометр
КРАТКОЕ ЗАКЛЮЧЕНИЕ
Мини-чат
Вам необходимо залогиниться.

Нет присланных сообщений.
Copyright © 2009