小编ova*_*vay的帖子

Java中的共享集合锁定

我有一个包含两个带有一些数据的Hashmaps的类.我希望每晚在地图中更新/重新加载数据(使用Quartz作业),并希望在数据刷新过程中锁定所有其他线程.

 public class A {

    private Map<String, Object> someMap1 = new ConcurrentHashMap<String, Object>();
    private Map<String, Object> someMap2 = new ConcurrentHashMap<String, Object>();

    public void reloadData() {
        someMap1.clear();
        someMap2.clear();

        // read new data here and re-fill the maps
        ...
    }

    public Object getDataFromMap(String key) {
        // do some logic here and return data from map
        return someObj;
    }
 }
Run Code Online (Sandbox Code Playgroud)

对于所有"读者"线程,getDataFromMap()方法应该是可访问的,而不会在数据刷新过程中出现任何阻塞.

另一方面,reloadData()方法应等待所有"读者"完成,然后阻止映射读取和重新加载数据.

reloadData()的'synchronized'修饰符不是解决方案,因为它阻止所有类和所有'读者',如果它们在getDataFromMap()逻辑中正在进行中.

java shared locking object

3
推荐指数
2
解决办法
1427
查看次数

标签 统计

java ×1

locking ×1

object ×1

shared ×1