Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате |
Форум программистов > Java: Общие вопросы > Синхронизация на чтение |
Автор: Рубильник 11.12.2018, 09:56 |
У платформы Java есть стандартные средства синхронизации через synchronized. У баз данных есть 2 вида блокировки : на чтение и на запись. Блокировка чтения мешает изменять данные, но не мешает их читать другому потоку. Блокировка на запись мешает всем действиям других потоков (как и действует в java synchronized). Есть ли возможность сделать нечто подобное, похожее на синхронизацию на чтение? Так, чтобы во время выборки не мешать читать данные другим потокам, но исключить модификацию этих данных. |
Автор: Рубильник 11.12.2018, 13:40 |
Пока придумал только через семафоры. Создаем семафор со значение например 20. Если нужно заблокировать на чтение выполняем acquire(), если нужно заблокировать на запись делаем acquire(20). Таким образом пишущий поток может войти в критический участок, только когда в нем нет никого. В тоже время в критическом участке могут быть одновременно до 20 читающих потоков. |
Автор: Kircul 12.12.2018, 01:36 |
https://examples.javacodegeeks.com/core-java/util/concurrent/locks-concurrent/readwritelock/java-readwritelock-example/ |
Автор: Рубильник 12.12.2018, 08:13 |
Спасибо. Именно то, что надо. |