我在我的应用程序中使用guava缓存来提高性能。我在LoadingCache中使用 putAll API在缓存中插入了850个条目。我配置的最大缓存大小为20K条目。我正在使用测试类 TestCacheSize :
测试缓存大小public class MetadataCacheKey{
// implementation
}
public class Metadata{
// implementation
}
public class MetadataCacheLoader extends CacheLoader<MetadataCacheKey, Optional<Metadata>> {
/**
* Guava cache does not support null values in cache. So null response from metadata source is wrapped in Optional
* and loaded in cache. This reduces look ups for keys which are not present in source.
*/
@Override
public Optional<Metadata> load(@NonNull MetadataCacheKey key) throws Exception {
return Optional.fromNullable(loadMetadataFromSource(key));
}
private Metadata loadMetadataFromSource(MetadataCacheKey key) {
// implementation
}
}
public class TestCacheSize {
public static void main(String[] args) {
LoadingCache<MetadataCacheKey, Optional<Metadata>> metadataCache = CacheBuilder.from(
"expireAfterWrite=4h,maximumSize=20000").build(new MetadataCacheLoader());
metadataCache.putAll(getAllMetadataFromDb());
System.out.println(metadataCache.size()); // output is 9467 (amusing)
System.out.println(metadataCache.asMap().size()); // output is 850 (as expected)
}
// assume always returns map with size equal to 850
private static Map<MetadataCacheKey, Optional<Metadata>> getAllMetadataFromDb(){
return new HashMap<MetadataCacheKey, Optional<Metadata>>();
}
}
来自缓存大小的javadocs:
size返回缓存中的近似条目数。
有人可以提供有关850到9467如何近似的见解吗?