Синхронизация методом взаимного исключения.



Сначала рассмотрим решение, основанное на взаимном исключении. В таком случае используется предоставляемый операционной системой двоичный семафор, у которого есть операции acquire (запросить) и release (освободить). Чтобы гарантировать взаимное исключение, каждая задача должна вызвать операцию acquire семафора readWriteSemaphore (изначально он установлен в единицу) перед тем, как пытаться получить доступ к хранилищу. Закончив работу с храни­лищем, задача обращается к операции release. При выполнении операции обновить надо не только записать в хранилище новое значение датчика, но и проверить условие тревоги.

Синхронизация нескольких читателей и писателей

Применение указанного метода позволяет нескольким читателям одновре­менно обращаться к хранилищу, но любой писатель получает монопольный до­ступ. Для этого применяются два двоичных семафора: readerSemaphore и readWriteSemaphore, инициализированных значением 1. Кроме того, хра­нится текущее число Читателей, первоначально равное нулю. Семафор readerSemaphore используется читателями, чтобы гарантировать взаимно исключающее обновление счетчика читателей. Семафор readWriteSemaphore за­действован писателями для обеспечения взаимно исключающего доступа к хра­нилищу. Но к данному семафору обращаются также и читатели. Он захватывается первым читателем перед началом чтения из хранилища и освобождается послед­ним читателем, закончившим чтение.

Синхронизация нескольких читателей и писателей с помощью монитора.

речь пойдет о применении мониторов для решения проблемы несколь­ких читателей и писателей.

к задаче посредством алгоритма читателей и писателей мониторы напрямую применяться не могут, так как операция читатьАналоговый Датчик должна одновременно выполняться несколькими читателями. Поэтому мы поступим иначе: инкапсулируем аспекты алгоритма читателей и писателей, касаю­щиеся синхронизации, в монитор и перепроектируем класс Хранилище Показа­ний Аналоговых Датчиков.

Синхронизация нескольких читателей и писателей без ущемления писателей

. Если от читателей постоянно поступают запросы на чтение, писателю в течение неопределенно долгого времени может быть отказано в доступе к хранилищу. Этот феномен на­зывается ущемлением писателя (writer starvation). Ниже показано решение про­блемы путем введения дополнительного семафора writer Waiting. Операция startWrite теперь должна захватить семафор writerWaiting до захвата се­мафора readWrite Semaphore. Операция startRead захватывает (и освобож­дает) семафор writerWaiting перед тем, как захватить reader Semaphore.

Поясним, для чего нужны такие изменения. Предположим, что несколько чи­тателей заняты чтением, а писатель в этот момент пытается обновить данные. Он успешно захватывает семафор writerWaiting, но дальше вынужден ждать, пока читатели освободят семафор readWriteSemaphore. Если приходит новый чи­татель, то он вызывает startRead и приостанавливается, ожидая освобождения семафора writerWaiting. Тем временем уже имеющиеся читатели заканчивают свои операции, и последний освобождает семафор readWriteSemaphore, кото­рый тут же переходит в распоряжение ожидающего писателя, а тот освобождает семафор writerWaiting, позволяя занять его читателю или писателю.

Проектирование разъемов для межзадачных   Коммуникаций

Классы-разъемы инкапсулируют детали межзадачных коммуникаций, например сильно и слабо связанный обмен сообщениями. Сервисы для межзадачных коммуникаций и синхронизации может предоставлять многозадачное ядро. По­добные механизмы есть также в некоторых языках параллельного программиро­вания, в частности Ada или Java. Но ни один из этих языков не поддерживает сла­бо связанный обмен сообщениями. Чтобы реализовать указанную возможность, необходимо спроектировать скрывающий информацию класс MessageQueue, инкапсулирующий очередь сообщений и предоставляющий операции для досту­па к ней. Классы такого вида называются разъемами.

Каждый разъем представляет собой монитор, одновременно обеспечивающий синхронизацию и скрывающий информацию о том, как это де­лается. В разъемах применяется синхронизация по условию. Такие мониторы могут использоваться как в однопроцессорной так и в многопро­цессорной системе с разделяемой памятью.


Дата добавления: 2018-08-06; просмотров: 248; Мы поможем в написании вашей работы!

Поделиться с друзьями:






Мы поможем в написании ваших работ!