Алгоритм Шиманского - Википедия - Szymańskis algorithm
Алгоритм взаимного исключения Шиманского это алгоритм взаимного исключения разработал компьютерный ученый д-р. Болеслав Шиманский, который имеет много полезных свойств, включая линейное ожидание,[1][2] и какое расширение[3] решил открытую проблему, опубликованную Лесли Лэмпорт[4] существует ли алгоритм с постоянным числом коммуникационных битов на процесс, который удовлетворяет всем разумным требованиям справедливости и отказоустойчивости, которые задумал Лампорт (в решении Лампорта использовалось n факторных коммуникационных переменных по сравнению с 5 Шиманским).
Алгоритм
Алгоритм моделируется на основе зала ожидания с дверным проемом для входа и выхода.[1] Первоначально входная дверь открыта, а выходная дверь закрыта. Все процессы, которые запрашивают вход в критическую секцию примерно в одно и то же время, попадают в комнату ожидания; последний из них закрывает входную дверь и открывает выходную дверь. Затем процессы поступают в критическую секцию один за другим (или в больших группах, если критическая секция позволяет это). Последний процесс, покинувший критическую секцию, закрывает выходную дверь и снова открывает входную дверь, поэтому может войти следующая партия процессов.
Реализация состоит из каждого процесса, имеющего флаг переменная, которая записывается этим процессом и читается всеми остальными (это свойство единственной записи желательно для эффективного тайник использование). Статус входной двери вычисляется путем считывания флагов всех процессов. Псевдокод приведен ниже:
# Протокол входафлаг[себя] ← 1 # Стоя вне зала ожиданияЖдите(все флаг[1..N] ∈ {0, 1, 2}) # Подождите, пока откроется дверьфлаг[себя] ← 3 # Стоя в дверяхесли любой флаг[1..N] = 1: # Другой процесс ожидает входа флаг[себя] ← 2 # Ожидание входа других процессов Ждите(любой флаг[1..N] = 4) # Подождите, пока процесс войдет, и закройте дверьфлаг[себя] ← 4 # Дверь закрытаЖдите(все флаг[1..себя-1] ∈ {0, 1}) # Подождите, пока все с более низким ID завершат протокол выхода# Критический раздел# ...# Выход из протоколаЖдите(все флаг[себя+1..N] ∈ {0, 1, 4}) # Убедитесь, что все в зале ожидания # понял, что дверь должна быть закрытафлаг[себя] ← 0 # Покинуть. Откройте дверь, если в зале ожидания никого нет
Обратите внимание, что порядок тестов «все» и «все» должен быть одинаковым. Также "любые" тесты должны выполняться не в self, а в другом потоке. Например, если тестом является любой флаг [1..N] = 1 и только флаг [self] = 1, то считается, что тест не прошел / вернул 0. Несмотря на интуитивное объяснение, алгоритм был непростым для доказать правоту однако из-за его благоприятных свойств было желательно доказательство правильности, и были представлены многочисленные доказательства.[2][5]
Рекомендации
- ^ а б Шиманский, Болеслав К. (1988). «Простое решение проблемы параллельного программирования Лампорта с линейным ожиданием». Материалы 2-й международной конференции по суперкомпьютерам - ICS '88. ICS '88: Материалы 2-й Международной конференции по суперкомпьютерам. Сен-Мало, Франция: ACM. С. 621–626. Дои:10.1145/55364.55425. ISBN 978-0-89791-272-3. S2CID 18612278.
- ^ а б Манна, Зоар; Пнуэли, Амир (1990). «Упражнение по проверке многопроцессорных программ». Красота - это наше дело: поздравление с днем рождения Эдсгеру В. Дейкстре. Springer Verlag. С. 289–301. ISBN 978-0-387-97299-2.
- ^ Шиманский, Болеслав (1990). «Возвращение к взаимному исключению» (PDF). Пятая Иерусалимская конференция по информационным технологиям. Иерусалим, Израиль: 110–117.
- ^ Лэмпорт, Лесли (1986). «Проблема взаимного исключения: часть II - постановка и решения». Журнал ACM. 33 (2): 327–348. CiteSeerX 10.1.1.32.9808. Дои:10.1145/5383.5385. S2CID 7387839.
- ^ де Ровер, Виллем-Поль; де Бур, Франк; Ханнеманн, Ульрих; Хуман, Йозеф; Лахнеч, Ясин; Поэль, Маннес; Цвиерс, Иов (ноябрь 2002 г.). Проверка параллелизма. Номер 54 в Кембриджских трактатах по теоретической информатике. Издательство Кембриджского университета. Дои:10.2277/0521806089 (неактивно 10.09.2020). ISBN 978-0-521-80608-4.CS1 maint: DOI неактивен по состоянию на сентябрь 2020 г. (связь)