Chr*_*ian 4 java multithreading synchronization
我在一个 HashMap 上使用来自多个线程的.get(...),.put(...)和.clear()操作。.put(...)并且.clear()在一个synchronized块内但.get(...)不是。我无法想象这会导致问题,但在我见过的其他代码.get()中几乎总是同步的。
获取/放置的相关代码
Object value = map.get(key);
if(value == null) {
synchronized (map) {
value = map.get(key); // check again, might have been changed in between
if(value == null) {
map.put(key, new Value(...));
}
}
}
Run Code Online (Sandbox Code Playgroud)
明确只是:
synchronized (map) {
map.clear();
}
Run Code Online (Sandbox Code Playgroud)
由于同步,写入操作将使缓存无效,并且get(...)返回 null 或实例。我真的看不出什么地方会出错,或者通过将.get(...)操作放入一个synchronized(map)块会改进什么。
这是一个简单的场景,它会在 unsynchronized 上产生问题get:
get,计算哈希桶号,并被抢占clear(),因此分配了较小的存储桶数组这是一个更复杂的场景:
get操作,计算哈希桶号,并被抢占put,意识到桶需要调整大小此时,A 可能不会找到正确的项目,因为它很可能位于不同索引的哈希桶中。这就是为什么也get需要同步的原因。
| 归档时间: |
|
| 查看次数: |
985 次 |
| 最近记录: |