Я проходил через the completely fair solution to the Readers/Writers problem, и порядок выпуска замков мне смущает. Я хотел бы знать, можем ли мы поменять порядок освобождения блокировки serviceQueue
и блокировки readCountAccess
в функции reader()
. Кажется противоречащим интуиции выпустить блокировки таким образом, если порядок не имеет значения. Но я не вижу, что не так, если вы освобождаете замки в обратном порядке (сначала readCountAccess
и , затем, затем serviceQueue
замок).Синхронизация читателей/писателей - порядок освобождения замков в честной версии
ответ
Это, вероятно, остаток от дней, когда вы могли бы оправдать первый выпуск более широкой блокировки (в данном случае serviceQueue
), если это не влияет на правильность, потому что другой поток может сразу же начать приобретать его, пока вы освобождаете больше узкий замок.
Представьте, что каждый приобретатель или выпуск занимает 1 единицу времени, а другая операция занимает 0 единиц времени. Читатель просто увеличил счетчик считывателей в момент времени 0, и в очереди очереди обслуживания появился следующий читатель.
Если
readCountAccess
не выпущен первый и второйserviceQueue
, следующий читатель может приобрестиserviceQueue
мьютекс не ранее, чем во время 3. Поэтому самое раннее это может быть сделано с церемонии регистрации блокировка чтения во время 6. выигравшей стороной здесь будут другие читатели, ожидающие выхода, и они менее важны, потому что они не должны также выпускатьresourceAccess
(потому что наш оригинальный читатель только что зарегистрировался как таковой).Если с другой стороны
serviceQueue
выпущен первый и второйreadCountAccess
, следующий читатель может приобрестиserviceQueue
мьютекс уже во время 2. Это означает, что это может быть сделано с замком церемонии регистрации чтения уже на время 5.
Я до сих пор предпочитаю, чтобы разблокировать с помощью симметричной схемы, хотя - она менее подвержены ошибкам, она имеет более широкое признание, и бремя доказывания того, что в настоящее время это хуже в любом случае, чем версия выше будет лежать на плечах сомневающихся.