Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Java: lock, concurrency

Как сделать потокобезопасную структуру данных для блокировки по определённому ID?

Вопрос проверяет умение проектировать блокировки для конкретных идентификаторов в многопоточной среде.

Короткий ответ

Используйте ConcurrentHashMap с ReentrantLock или synchronized:

Map<Long, Lock> locks = new ConcurrentHashMap<>();
Lock lock = locks.computeIfAbsent(id, k -> new ReentrantLock());
lock.lock();
try {
    	// Критическая секция
} finally {
   	lock.unlock();
}

Длинный ответ

1. Реализация с ReentrantLock:

  • Каждому ID соответствует свой Lock.

  • computeIfAbsent гарантирует атомарность создания.

2. Альтернатива с synchronized:

Map<Long, Object> locks = new ConcurrentHashMap<>();
Object lock = locks.computeIfAbsent(id, k -> new Object());
synchronized (lock) {
    	// Критическая секция
}

Уровень

  • Рейтинг:

    2

  • Сложность:

    7

Навыки

  • Java

    Java

Ключевые слова

#lock

#concurrency

Подпишись на Java Developer в телеграм