- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我经常想要访问(并且可能添加/删除)给定 ConcurrentMap
的元素,以便一次只有一个线程可以访问任何单个键。做这个的最好方式是什么?同步 key 本身不起作用:其他线程可能通过 equal
实例访问相同的 key 。
如果答案仅适用于 guava 构建的 map 就足够了MapMaker
.
最佳答案
在这里查看一个简单的解决方案 Simple Java name based locks?
编辑:该解决方案从解锁到锁定具有明确的先行关系。然而,下一个解决方案(现已撤回)却没有。 ConcurrentMap
javadoc 太轻而无法保证这一点。
(Withdrawn) 如果你想重用你的 map 作为锁池,
private final V LOCK = ...; // a fake value
// if a key is mapped to LOCK, that means the key is locked
ConcurrentMap<K,V> map = ...;
V lock(key)
V value;
while( (value=map.putIfAbsent(key, LOCK))==LOCK )
// another thread locked it before me
wait();
// now putIfAbsent() returns a real value, or null
// and I just sucessfully put LOCK in it
// I am now the lock owner of this key
return value; // for caller to work on
// only the lock owner of the key should call this method
unlock(key, value)
// I put a LOCK on the key to stall others
// now I just need to swap it back with the real value
if(value!=null)
map.put(key, value);
else // map doesn't accept null value
map.remove(key)
notifyAll();
test()
V value = lock(key);
// work on value
// unlock.
// we have a chance to specify a new value here for the next worker
newValue = ...; // null if we want to remove the key from map
unlock(key, newValue); // in finally{}
这非常困惑,因为我们出于两个不同的目的重复使用 map 。最好将锁池作为一个单独的数据结构,让 map 简单地作为 k-v 存储。
关于java - 同步对 ConcurrentMap 中给定键的访问,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6758587/
ConcurrentMap 的 JavaDoc - putIfAbsent 说: /** * If the specified key is not already associated
我有这个 ConcurrentMap ConcurrentMap companyLogo = new MapMaker() .concurrencyLevel(
我该如何实现 class CaseInsensitiveConcurrentMap implements ConcurrentMap 就像ConcurrentHashMap 一样工作除了不区分大小写地
根据ConcurrentMap Javadoc : Memory consistency effects: As with other concurrent collections, actions
我有一段代码可以由多个线程执行,该代码需要执行 I/O 绑定(bind)操作,以便初始化存储在 ConcurrentMap 中的共享资源。我需要使这段代码线程安全,并避免不必要的调用来初始化共享资源。
我有一个 ConcurrentHashMap 累积了一些应该定期发送到某处的更改(用于某种复制)。关于更改,只有任何关键事项的最新值。 所以我需要获取并删除一些快照。快照不需要是原子的,只要它的每个条
ConcurrentMap 指定putIfAbsent() 的返回值为: the previous value associated with the specified key, or null i
我有一个有趣的问题需要帮助。我已经为两个不同的条件实现了几个队列,一个基于 FIFO,另一个基于键的自然顺序(ConcurrentMap)。也就是说,您可以想象两个队列具有相同的数据,只是顺序不同。我
在 Java 中,我经常需要懒惰地获取 ConcurrentMap 的条目,仅在必要时才创建。 例如我可能有 ConcurrentMap> a = new ConcurrentHashMap<>();
我经常想要访问(并且可能添加/删除)给定 ConcurrentMap 的元素,以便一次只有一个线程可以访问任何单个键。做这个的最好方式是什么?同步 key 本身不起作用:其他线程可能通过 equal
休息服务有许多彼此不相关的客户。每个客户都可以随时开始投票过程。一旦客户添加了第一票,我就会在 中创建一个条目 ConcurrentMap> votesByCustomer; 每个投票都有 voteT
我有以下代码。即使集合本身不是线程安全的,它也会是线程安全的吗? private ConcurrentMap> proxyRoles = new ConcurrentHashMap>(); p
使用 Java 8,我在 java.util.concurrent.ConcurrentMap 上实现了一个包装器接口(interface),特别是 remove(Object key)方法。由于我需
我有一段代码可以由多个线程执行,这些线程需要执行 I/O 绑定(bind)操作以初始化存储在 ConcurrentMap 中的共享资源。我需要使此代码线程安全并避免不必要的调用来初始化共享资源。这是错
AbstractConcurrentMap是Groovy中的核心类,它用于存储在运行时添加到Groovy类中的动态属性。我正在使用 Grails 2.1.2 和 Groovy 1.8.8,但我认为所有
我正在声明一个 MultiMap,并想知道将键设置为 Integer 是否是一个好主意。使用整数键与字符串键会加快检索值的速度吗? MultiMap mmCustomerOrders = hz.get
在 Java 的 ConcurrentMap 中, 有 remove(key, expectedValue) ,这将返回以下之一: 预期值在那里,但已被删除。 预期值不存在,因此未被删除。 但我想要得
很多人将 ConcurrentMap 称为缓存。 这样做是个好主意吗: public List listTasks(final ProcessDefinition def, final boolean
我正在尝试反序列化其中包含 ConcurrentMap 的对象,但出现异常。 Caused by: java.lang.IllegalArgumentException: Can not set ja
我有一个java类来处理多线程订阅服务。通过实现 Subscribable 接口(interface),可以将任务提交到服务并定期执行。代码草图如下所示: import java.util.concu
我是一名优秀的程序员,十分优秀!