Class AbstractValueAdaptingCache
java.lang.Object
org.springframework.cache.support.AbstractValueAdaptingCache
- All Implemented Interfaces:
- Cache
- Direct Known Subclasses:
- CaffeineCache,- ConcurrentMapCache,- JCacheCache
Common base class for 
Cache implementations that need to adapt
 null values (and potentially other such special values) before
 passing them on to the underlying store.
 Transparently replaces given null user values with an internal
 NullValue.INSTANCE, if configured to support null values
 (as indicated by isAllowNullValues()).
- Since:
- 4.2.2
- Author:
- Juergen Hoeller
- 
Nested Class SummaryNested classes/interfaces inherited from interface org.springframework.cache.CacheCache.ValueRetrievalException, Cache.ValueWrapper
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedAbstractValueAdaptingCache(boolean allowNullValues) Create anAbstractValueAdaptingCachewith the given setting.
- 
Method SummaryModifier and TypeMethodDescriptionprotected ObjectfromStoreValue(Object storeValue) Convert the given value from the internal store to a user value returned from the get method (adaptingnull).Return the value to which this cache maps the specified key.<T> TReturn the value to which this cache maps the specified key, generically specifying a type that return value will be cast to.final booleanReturn whethernullvalues are allowed in this cache.protected abstract ObjectPerform an actual lookup in the underlying store.protected ObjecttoStoreValue(Object userValue) Convert the given user value, as passed into the put method, to a value in the internal store (adaptingnull).protected Cache.ValueWrappertoValueWrapper(Object storeValue) Wrap the given store value with aSimpleValueWrapper, also going throughfromStoreValue(java.lang.Object)conversion.Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.springframework.cache.Cacheclear, evict, evictIfPresent, get, getName, getNativeCache, invalidate, put, putIfAbsent, retrieve, retrieve
- 
Constructor Details- 
AbstractValueAdaptingCacheprotected AbstractValueAdaptingCache(boolean allowNullValues) Create anAbstractValueAdaptingCachewith the given setting.- Parameters:
- allowNullValues- whether to allow for- nullvalues
 
 
- 
- 
Method Details- 
isAllowNullValuespublic final boolean isAllowNullValues()Return whethernullvalues are allowed in this cache.
- 
getDescription copied from interface:CacheReturn the value to which this cache maps the specified key.Returns nullif the cache contains no mapping for this key; otherwise, the cached value (which may benullitself) will be returned in aCache.ValueWrapper.- Specified by:
- getin interface- Cache
- Parameters:
- key- the key whose associated value is to be returned
- Returns:
- the value to which this cache maps the specified key,
 contained within a Cache.ValueWrapperwhich may also hold a cachednullvalue. A straightnullbeing returned means that the cache contains no mapping for this key.
- See Also:
 
- 
getDescription copied from interface:CacheReturn the value to which this cache maps the specified key, generically specifying a type that return value will be cast to.Note: This variant of getdoes not allow for differentiating between a cachednullvalue and no cache entry found at all. Use the standardCache.get(Object)variant for that purpose instead.- Specified by:
- getin interface- Cache
- Parameters:
- key- the key whose associated value is to be returned
- type- the required type of the returned value (may be- nullto bypass a type check; in case of a- nullvalue found in the cache, the specified type is irrelevant)
- Returns:
- the value to which this cache maps the specified key
 (which may be nullitself), or alsonullif the cache contains no mapping for this key
- See Also:
 
- 
lookupPerform an actual lookup in the underlying store.- Parameters:
- key- the key whose associated value is to be returned
- Returns:
- the raw store value for the key, or nullif none
 
- 
fromStoreValueConvert the given value from the internal store to a user value returned from the get method (adaptingnull).- Parameters:
- storeValue- the store value
- Returns:
- the value to return to the user
 
- 
toStoreValueConvert the given user value, as passed into the put method, to a value in the internal store (adaptingnull).- Parameters:
- userValue- the given user value
- Returns:
- the value to store
 
- 
toValueWrapperWrap the given store value with aSimpleValueWrapper, also going throughfromStoreValue(java.lang.Object)conversion. Useful forget(Object)andCache.putIfAbsent(Object, Object)implementations.- Parameters:
- storeValue- the original value
- Returns:
- the wrapped value
 
 
-