在此示例中,我有一个内部类,在想象的ExampleCache类中定义了一个read-through CacheLoaderWriter,该类抽象缓存操作,使第三方只认为它们正在访问数据结构(键值对)。我的问题涉及loadAll方法。
如果loadAll被编写为并行写入EhCache,是否存在记录突变或不稳定的风险? EhCache是否建立用于处理用户定义的并发性?
如果loadAll被编写为并行写入EhCache,是否存在记录突变或不稳定的风险? EhCache是否建立用于处理用户定义的并发性?
class ExampleCacheLoader implements CacheLoaderWriter<String, ArrayList> {
private HashMap<String, ArrayList> map;
public CacheLoader() {
map = new HashMap<>();
}
@Override
public ArrayList<String> load(String s) throws Exception {
Map.Entry<String, ArrayList<String>> personEntry = getPersonAliases(s);
if(!map.containsKey(personEntry.getKey())){
map.put(personEntry.getKey(), personEntry.getValue());
}
return map.get(personEntry.getKey());
}
@Override
public Map<String, ArrayList> loadAll(
Iterable<? extends String> keys) throws Exception {
Map<String, ArrayList> localTempMap = new HashMap<>();
Stream keyStream = StreamSupport.stream(entries.spliterator(), true);
keyStream.forEach(key -> {
localTempMap.putIfAbsent(
getterExample(key).getKey(),
getterExample(key).getValue());
});
map.putAll(localTempMap);
return localTempMap;
}
.
.
.