我有兴趣知道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;
}
Run Code Online (Sandbox Code Playgroud)
这里返回的类型是Map throws error java.lang.ClassCastException:com.google.common.cache.LocalCache $ LocalLoadingCache不能转换为java.util.Map(知道加载Cache对象不能是Map类型的事实)
如果这不是使用LoadingCache的正确实现方式,那么如何在LoadingCache的Component中注入数据,以便它可以用作Cache.
您的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;
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8557 次 |
| 最近记录: |