K - Cache lookup key typeV - Cache instance value type (must not be a CacheValue)D - Data type for creating a new instance valuepublic abstract class SoftCache<K,V,D> extends CacheBase<K,V,D>
References via CacheValues.
To use, instantiate a subclass which implements the createInstance() method,
and call get() with the key and the data. The get() call will use the data
only if it needs to call createInstance(), otherwise the data is ignored.
When caching instances while the CacheValue "strength" is SOFT,
the Java runtime can later release these instances once they are not used any more at all.
If such an instance is then requested again,
the getInstance() method will call createInstance() again and reset the CacheValue.
The cache holds on to its map of keys to CacheValues forever.
A value can be null if createInstance() returns null. In this case, it must do so consistently for the same key and data.
| Constructor and Description |
|---|
SoftCache() |
| Modifier and Type | Method and Description |
|---|---|
V |
getInstance(K key,
D data)
Retrieves an instance from the cache.
|
createInstancepublic final V getInstance(K key, D data)
CacheBasegetInstance in class CacheBase<K,V,D>key - Cache lookup key for the requested instancedata - Data for createInstance() if the instance is not already cached