|
Модераторы: LSD, AntonSaburov |
|
Рубильник |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 6.6.2016 Репутация: нет Всего: нет |
У платформы Java есть стандартные средства синхронизации через synchronized.
У баз данных есть 2 вида блокировки : на чтение и на запись. Блокировка чтения мешает изменять данные, но не мешает их читать другому потоку. Блокировка на запись мешает всем действиям других потоков (как и действует в java synchronized). Есть ли возможность сделать нечто подобное, похожее на синхронизацию на чтение? Так, чтобы во время выборки не мешать читать данные другим потокам, но исключить модификацию этих данных. |
|||
|
||||
Рубильник |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 6.6.2016 Репутация: нет Всего: нет |
Пока придумал только через семафоры.
Создаем семафор со значение например 20. Если нужно заблокировать на чтение выполняем acquire(), если нужно заблокировать на запись делаем acquire(20). Таким образом пишущий поток может войти в критический участок, только когда в нем нет никого. В тоже время в критическом участке могут быть одновременно до 20 читающих потоков. |
|||
|
||||
Kircul |
|
|||
Бывалый Профиль Группа: Участник Сообщений: 166 Регистрация: 20.2.2007 Репутация: 6 Всего: 7 |
||||
|
||||
Рубильник |
|
|||
Новичок Профиль Группа: Участник Сообщений: 19 Регистрация: 6.6.2016 Репутация: нет Всего: нет |
Спасибо. Именно то, что надо.
|
|||
|
||||
Правила форума "Java" | |
|
Если Вам помогли, и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, LSD, AntonSaburov, powerOn, tux, javastic. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Java: Общие вопросы | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |