Проблема: Мне нужно реализовать кэш объектов. Кэш должен быть потокобезопасным и заполнять значения по требованию (ленивая загрузка). Значения извлекаются через веб-сервис по ключу (медленная работа). Поэтому я решил использовать ConcurrentDictionary и его метод GetOrAdd(), который имеет метод фабрики значений, предполагая, что операция является атомарной и синхронизированной. К сожалению, в статье MSDN я нашел следующее утверждение: Как добавлять и удалять элементы из ConcurrentDictionary:
Кроме того, хотя все методы ConcurrentDictionary
потокобезопасен, не все методы являются атомарными, в частности GetOrAdd и
AddOrUpdate. Пользовательский делегат, передаваемый этим методам,
вызывается вне внутренней блокировки словаря.
Ну, это прискорбно, но все же не отвечает полностью на мой ответ.
Вопрос: Фабрика значений вызывается только один раз для каждого ключа? В моем конкретном случае: возможно ли, что несколько потоков, которые ищут один и тот же ключ, порождают несколько запросов к веб-сервису на одно и то же значение?
Подробнее здесь: https://stackoverflow.com/questions/316 ... ethod-only
Гарантируется ли ConcurrentDictionary.GetOrAdd() вызов valueFactoryMethod только один раз для каждого ключа? ⇐ C#
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение