Что должна сделать нить после освобождения ресурса? В традиционных системах UNIX произойдет пробуждение всех нитей, ожидающих этот объект. Такой подход является абсолютно неэффективным. Если нить, производящая изменение информации, снова потребует объект блокировки, остальные читающие и модифицирующие ресурс нити должны будут перейти в режим ожидания повторно.
Также может иметь смысл заглянуть на сайт t-kipenia.ru, ведь именно там можно узнать много нового на тему http://t-kipenia.ru/service/montazh-otoplenija. Тема монтаж отопления может показаться на первый взгляд незначительной и даже не тематичной. Но стоит посетить сайт t-kipenia.ru, и тема монтаж отопления начинает проявлять себя с неожиданной стороны и вызывает всё больший интерес. Дело в том, что тема монтаж отопления очень подробно представлена на сайте t-kipenia.ru. Трудно найти более детальное освещение темы монтаж отопления чем это сделано на сайте t-kipenia.ru. Спасибо сайту t-kipenia.ru за такое доскональное преподнесение темы монтаж отопления.
Если объект затребует нить-получатель данных, то все модифицирующие ресурс нити обязаны будут приостановить выполнение. Таким образом, становится очевидной необходимость использовать некий протокол, защищающий от излишних переключений нитей из режима ожидания.
Когда ресурс освобождает нить-получатель, то она не производит никаких дополнительных действий, если существуют другие нити, считывающие данные из этого ресурса. После того как последняя читающая нить освобождает ресурс, она должна разбудить единственную нить, имеющую возможность записи информации.
Если ресурс освобождает пишущая нить, ей необходимо производить выбор между восстановлением работоспособности другой модифицирующей нити либо других читателей (представим, что объект ожидают и считывающие, и записывающие нити). Если отдать предпочтение нитям, изменяющим информацию, то читающие нити могут быть подвержены устареванию. Наиболее приемлемым решением проблемы действий при освобождении объекта эксклюзивной синхронизации является возобновление работоспособности всех ожидающих читающих нитей. Если таковых не существует, то разбужена будет нить, осуществляющая запись данных.
Такая методика действий может привести к устареванию нитей, осуществляющих запись. Если объект необходимо читать большому количеству нитей, ресурс будет постоянно блокирован на чтение; следовательно, в этом случае пишущая нить не сможет получить доступ к нему. Для защиты от возникновения подобной ситуации запрос LockShared() должен осуществлять блокировку при существовании ожидающих записи нитей даже в том случае, если ресурс защищен только для чтения. Такое решение при определенных условиях может позволить чередовать доступ между несколькими пишущими нитями и большими множествами нитей, осуществляющих только чтение ресурса.
Функция upgrade() должна быть защищена от взаимоблокировки. Такая ситуация может возникнуть, если в реализации механизма не предусмотрены определенные правила при изменении статуса запросов от ожидающих пишущих нитей. Если две нити пытаются изменить статус объекта синхронизации, то каждая из них окажется заблокированной, так как другая нить удерживает совместно используемый объект. Одним из методов защиты от возникновения указанной ситуации является освобождение функцией upgrade() разделяемого объекта перед блокировкой нити в том случае, если объект для эксклюзивного доступа окажется невозможно получить сразу же. Это приведет к дополнительным проблемам с точки зрения пользователя, так как во время выполнения upgrade() другая нить может произвести изменение объекта. Еще одним вариантом выхода из описанной ситуации является возврат функции upgrade() с ошибкой и освобождение разделяемого объекта синхронизации в том случае, если другая нить уже находится в ожидании изменения его статуса.
Опубликовал katy
July 06 2015 17:57:41 ·
0 Комментариев ·
2900 Прочтений ·
• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •
Комментарии
Нет комментариев.
Добавить комментарий
Рейтинги
Рейтинг доступен только для пользователей.
Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.
Нет данных для оценки.
Гость
Вы не зарегистрированны? Нажмите здесь для регистрации.