我很想知道google guava 11.0库中引入的loadAll方法实现的有效方法是什么。
以下是描述加载所有方法实现扩展的代码 根据CachesExplained的例子
LoadingCache<Key, Graph> graphs = CacheBuilder.newBuilder().maximumSize(1000)
.refreshAfterWrite(1, TimeUnit.MINUTES)
.build(
new CacheLoader<Key, Graph>() {
public Graph load(Key key) { // no checked exception
return getGraphFromDatabase(key);
}
public Map<Key, Graph> loadAll(Iterable<? extends K> keys) {
return getAllGraphsFromDatabase(keys);
}
}
);
private Map<Key, Graph> getAllGraphsFromDatabase(Iterable<? extends key> keys)
{
lListOfGraph = //resultset got from DB Call
for (lCount = 0; lCount < lListOfGraph.size(); lCount++)
{
lGraph = (Graph)lListOfGraph.get(lCount).get(0);
graphs.asMap().put((key , lGraph);
}
return (Map<key, Graph>) graphs;
}
这里返回类型是Map throws error java.lang.ClassCastException:com.google.common.cache.LocalCache $ LocalLoadingCache不能转换为java.util.Map(知道加载Cache对象不能是类型的事实地图)
如果这不是使用LoadingCache的正确实现方式 如何在LoadingCache的Component中注入数据,以便它可以用作Cache。
答案 0 :(得分:5)
您的getAllGraphsFromDatabase
方法应该从底层数据存储中获取值。 LoadingCache
实现处理将返回的值添加到地图中。
我认为您的加载方法应如下所示:
private Map<Key, Graph> getAllGraphsFromDatabase(Iterable<? extends key> keys)
{
final List<Graph> lListOfGraph = //resultset got from DB Call
final Map<Key, Graph> map = new HashMap<Key, Graph>(listOfGraph.size());
for (final Graph graph : lListOfGraph)
map.put(graph.getKey(), graph);
return map;
}