Наиболее важным свойством простой блокировки является продолжение выполнения нити (или использования процессорного времени) во время ожидания освобождения ресурса. Следовательно, такую блокировку можно применять только для коротких промежутков ожидания.
Также может иметь смысл заглянуть на сайт akva-sg.ru, ведь именно там можно узнать много нового на тему http://www.akva-sg.ru/#!price/cobq. Тема резина для пруда может показаться на первый взгляд незначительной и даже не тематичной. Но стоит посетить сайт akva-sg.ru, и тема резина для пруда начинает проявлять себя с неожиданной стороны и вызывает всё больший интерес. Дело в том, что тема резина для пруда очень подробно представлена на сайте akva-sg.ru. Трудно найти более детальное освещение темы резина для пруда чем это сделано на сайте akva-sg.ru. Спасибо сайту akva-sg.ru за такое доскональное преподнесение темы резина для пруда.
В частности, эти операции не следует производить совместно с блокировкой нитей. Рекомендуется также приостановить обработку прерываний до вызова объекта простой блокировки, что гарантирует уменьшение общей продолжительности ожидания.
Главным условием применения простой блокировки является использование ресурса другой нитью (выполняющейся на другом процессоре), в то время как первая нить находится в режиме ожидания ресурса. Следовательно, использование таких объектов возможно только в многопроцессорных архитектурах. На однопроцессорной машине нить, находящаяся в цикле ожидания освобождения ресурса, не выйдет из этого цикла никогда. Однако многопроцессорные алгоритмы должны работать корректно при любом количестве процессоров в системе, в том числе и в случае одного CPU. Для этого необходимо ограничить применение правила занятия процессора нитью при ожидании ресурса. В частности, на однопроцессорных машинах ни одна нить не должна иметь право входить в режим ждущего цикла при применении взаимоисключения.
Основным достоинством объектов простой блокировки является невысокое использование ресурсов системы. Блок не содержит никакой информации внутри себя, а операции занятия и освобождения объекта требуют выполнения всего лишь одной команды для каждой из них. Простая блокировка идеально подходит для блокировки структур данных, к которым производятся частые обращения, например для удаления элемента из двунаправленного связанного списка или проведения операции загрузки, изменения и сохранения переменной. Из сказанного можно сделать вывод, что применение объектов простой блокировки наиболее целесообразно для защиты тех структур данных, которые не нуждались в таковой в однопроцессорных системах. Однако простые объекты блокировки применяются и для более сложной защиты, что будет продемонстрировано в следующих разделах главы. Например, они могут быть использованы совместно с семафорами для подтверждения неделимости операции.
Условные переменные
Условные переменные представляют собой более сложный механизм блокировки, основанный на логике предикатов (выражения, имеющие значения TRUE и FALSE). Такие переменные позволяют нити приостановить работу в ожидании совместно используемых ресурсов и возобновить выполнение только одной или сразу всех ожидающих нитей при изменении значения выражения. Использование условных переменных является более приемлемым, чем применение простых блокировок.
Представьте ситуацию, в которой одна или несколько нитей серверного приложения находятся в ожидании запросов клиентов. Поступающие запросы передаются ожидающим их нитям. Если ни одна из нитей не может в данный момент обработать поступивший запрос, то последний будет поставлен в очередь.
Когда очередная нить серверного приложения заканчивает работу с одним запросом и становится готовой обрабатывать новый, то сначала она проверяет очередь. Если в ней будет обнаружено сообщение, нить удалит его из очереди и начнет обработку запроса. Если очередь окажется пустой, нить приостанавливает выполнение в ожидании поступления нового запроса. Обработка сообщений может быть реализована при помощи условных переменных, ассоциируемых с очередью запросов. В этом случае совместно используемыми данными является очередь сама по себе, а проверяемым условием — выражение «очередь не пуста».
Опубликовал katy
July 06 2015 16:22:32 ·
0 Комментариев ·
2656 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.