170 похожих чатов

Привет. Пара вопросов по ConcurrentHashMap. Допустим у меня есть ConcurrentHashMap<String, User> users. В

User есть AtomicInteger referenceCounter.

Каждый раз я достаю пользователя с помощью метода compute и увеличиваю referenceCounter на 1.
В конце метода я еще раз вызываю compute и на этот раз уменьшаю referenceCounter. Если referenceCounter == 0 и при этом выполняется еще некоторое дополнительное условие, то я удаляю этого пользователя из мапы.

Теперь вопросы:
1. Если я читаю/пишу referenceCounter только из одной и той же ConcurrentHashMap, могу ли я использовать int для referenceCounter вместо AtomicInteger? ConcurrentHashMap же все сама синхронизирует.
2. Как более правильно реализовать конкурентные вставки/удаления из ConcurrentHashMap?
3. Где вообще можно посмотреть более сложные примеры использования конкурентных структур?

Спасибо.

Update: буду смотреть в сторону Guava Striped<Lock>, подходит для моей задачи.

1 ответов

4 просмотра

1) ну конечно же нет, у вас же конкурентная мапа не просто так, да? Значит вот эта свистопляска с помпьютами и +-1 происходит из нескольких потоков, верно? Ну и ответ, вроде, очевиден почему нельзя обновлять int из нескольких потоков 2) ну вот методы из 8ки compute, computeIfAbsent, putIfAbsent, etc - это, самый удобный способ, во всяком случае тут за вас решили максимальное количество проблем многопоточности, единственное что от вас требуется - это написать либо чистую функцию, которая вычисляет значение, либо корректно синхронизировать доступ к каким-нибудь внешним объектам, коллекциям. 3) хз, но я думаю самое главное при работе с такими вещами - это понимание hb и контрактов коллекции. Вы же в курсе что в джаве тоже есть https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/locks/StampedLock.html ?

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Добрый день, чат. Мне в очередь из других RabbitMQ по shovel валятся метрики в формате текста для Prometheus. Помогите пожалуйста подружить RabbitMQ и Prometheus, чтобы он (...
Aleksey
4
@ahndmn @ayaw0_0 здарова, на чем пишете?
Aiwan \ (•◡•) / _bot
7
Карта сайта