gpt4 book ai didi

java - 根据值(value)锁定/解锁?

转载 作者:行者123 更新时间:2023-12-01 07:03:41 25 4
gpt4 key购买 nike

我有一个由 3 个并发线程在对象实例上调用的方法。我感兴趣的锁是基于值而不是对象。例如,如果两个线程 (T1,T2) 正在处理 RecordID=123,T3 正在处理 RecordID=456。该方法应仅锁定 T2,而 T3 应继续执行。

目前,我正在使用 Lock,但如果 T1 获得锁定,它将锁定 T2 和 T3。

public void doSomething(String id){
try {
lock.lock();
MyRecord r = find(id);
...
....
} finally{
lock.unlock();
}
}

最佳答案

解决方案可能是基于哈希码实现分段锁定,类似于 ConcurrentHashMap 中的实现方式:

int concurrencyLevel = 1 << 8;   // 256 locks
final Lock[] locks = new Lock[concurrencyLevel];
// initialize locks

void doSomething(String id) {
Lock lock = locks[id.hashCode() & (concurrencyLevel - 1)]; // select one of 256 locks
lock.lock();
try {
// do some work
} finally {
lock.release();
}
}

相同的id值始终具有相同的哈希码,因此它们将使用池中的相同锁。

关于java - 根据值(value)锁定/解锁?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33263984/

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