gpt4 book ai didi

java - 如何使原子成为 ConcurrentHashMaps 上的嵌套迭代操作?

转载 作者:行者123 更新时间:2023-11-30 10:38:54 24 4
gpt4 key购买 nike

我有一个包含另一个对象 (sessionCollection) 的 ConcurrentHashMap subscriptions,我需要执行以下迭代操作:

  subscriptions.values().forEach(sessionCollection -> 
sessionCollection.removeAllSubscriptionsOfSession(sessionId));

其中 sessionCollection.removeAllSubscriptionsOfSessionsessionCollection 中的集合(也是 ConcurrentHashMap)执行另一个迭代操作:

// inside SessionCollection:
private final ConcurrentHashMap<String, CopyOnWriteArrayList<String>> topicsToSessions =
new ConcurrentHashMap<>();

public void removeAllSubscriptionsOfSession(String sessionId) {
// Remove sessions from all topics on record
topicsToSessions.keySet().forEach(topicSessionKey ->
removeTopicFromSession(sessionId, topicSessionKey));
}

进行这个整体原子操作的步骤是什么?

最佳答案

ConcurrentHashMap有批处理操作(forEach*()),但它们对于整个 map 来说不是原子的。在 map 上进行原子批量更改的唯一方法是自己实现所有必要的同步。例如,通过使用 synchronized显式阻止或通过为您的 map 创建包装器(或扩展)来在需要时处理同步。在这种情况下,一个简单的 HashMap就足够了,因为无论如何您都必须进行同步:

public class SubscriptionsRegistry {
private final Map<Integer, SessionCollection> map = new HashMap<>();

public synchronized void removeSubscriptions(Integer sessionId) {
map.values().forEach(...);
}

public synchronized void addSubscription(...) {
...
}

...
}

您还需要保护主题到 session 映射(至少是它们的可修改版本)以免泄露到您的 SubscriptionsRegistry 之外。 ,所以没有人能够在没有适当同步的情况下修改它们。

关于java - 如何使原子成为 ConcurrentHashMaps 上的嵌套迭代操作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39507614/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com