Jump to content

Ложное пробуждение

В вычислениях происходит ложное пробуждение , когда поток просыпается после ожидания условной переменной без удовлетворения этой переменной. Его называют ложным, потому что поток, по-видимому, был разбужен без всякой причины. Однако обычно они происходят потому, что между моментом, когда была сигнализирована условная переменная, и моментом, когда ожидающий поток наконец запустился, другой поток запустился и изменил условие, вызывая состояние гонки . Если поток просыпается на секунду, он проиграет гонку и произойдет ложное пробуждение. [ нужна ссылка ]

Проблема ложного пробуждения может усугубиться в многопроцессорных системах. Когда несколько потоков ожидают одной условной переменной, система может решить разбудить все потоки, когда об этом поступит сигнал. Система рассматривает каждое signal( ) чтобы разбудить один поток как broadcast( ) чтобы разбудить их всех, тем самым нарушив любое возможно ожидаемое соотношение 1:1 между сигналами и пробуждением. [1] Если десять потоков ожидают, только один выиграет, а остальные девять испытают ложное пробуждение. [ нужна ссылка ]

Чтобы обеспечить гибкость реализации при работе с ошибками и гонками внутри операционной системы, переменным состояния также может быть разрешено возвращаться из ожидания, даже если не сигнализируется, хотя неясно, сколько реализаций это делают. В реализации условных переменных Solaris ложное пробуждение может произойти без назначения условия, если процесс является сигнальным; системный вызов ожидания прерывается и возвращается EINTR. [2] Реализация условных переменных в p-потоке Linux гарантирует, что этого не произойдет. [3] [4]

Поскольку может произойти ложное пробуждение, когда поток просыпается по условной переменной, он всегда должен проверять, что искомое условие удовлетворено. Если это не так, ему следует вернуться в режим ожидания с условной переменной, ожидая другой возможности. [5]

  1. ^ Раймонд Чен (1 февраля 2018 г.). «Ложные пробуждения в переменных состояния Win32» . Проверено 9 мая 2020 г.
  2. ^ «Прерванное ожидание переменных состояния (только потоки Solaris)» . Корпорация Оракл . Проверено 9 мая 2020 г.
  3. ^ «pthread_cond_wait(3) — справочная страница Linux» . сайт die.net . Проверено 9 мая 2020 г. Эти функции не должны возвращать код ошибки [EINTR].
  4. ^ «pthread_cond_timedwait, pthread_cond_wait — ожидание по условию» . Открытая группа . 2018 . Проверено 9 мая 2020 г.
  5. ^ Арпачи-Дюссо, Ремзи; Арпачи-Дюссо, Андреа (ноябрь 2023 г.). «Переменные состояния» (PDF) . Операционные системы: три простых элемента .
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: adeec875f4e311aec9f2e89826df69bd__1721295300
URL1:https://arc.ask3.ru/arc/aa/ad/bd/adeec875f4e311aec9f2e89826df69bd.html
Заголовок, (Title) документа по адресу, URL1:
Spurious wakeup - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)