public class ConcurrentMapCache extends AbstractValueAdaptingCache
Cache implementation based on the
 core JDK java.util.concurrent package.
 Useful for testing or simple caching scenarios, typically in combination
 with SimpleCacheManager or
 dynamically through ConcurrentMapCacheManager.
 
Note: As ConcurrentHashMap (the default implementation used)
 does not allow for null values to be stored, this class will replace
 them with a predefined internal object. This behavior can be changed through the
 ConcurrentMapCache(String, ConcurrentMap, boolean) constructor.
Cache.ValueRetrievalException, Cache.ValueWrapper| Modifier | Constructor and Description | 
|---|---|
|   | ConcurrentMapCache(String name)Create a new ConcurrentMapCache with the specified name. | 
|   | ConcurrentMapCache(String name,
                  boolean allowNullValues)Create a new ConcurrentMapCache with the specified name. | 
|   | ConcurrentMapCache(String name,
                  ConcurrentMap<Object,Object> store,
                  boolean allowNullValues)Create a new ConcurrentMapCache with the specified name and the
 given internal  ConcurrentMapto use. | 
| protected  | ConcurrentMapCache(String name,
                  ConcurrentMap<Object,Object> store,
                  boolean allowNullValues,
                  SerializationDelegate serialization)Create a new ConcurrentMapCache with the specified name and the
 given internal  ConcurrentMapto use. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | clear()Remove all mappings from the cache. | 
| void | evict(Object key)Evict the mapping for this key from this cache if it is present. | 
| protected Object | fromStoreValue(Object storeValue)Convert the given value from the internal store to a user value
 returned from the get method (adapting  null). | 
| <T> T | get(Object key,
   Callable<T> valueLoader)Return the value to which this cache maps the specified key, obtaining
 that value from  valueLoaderif necessary. | 
| String | getName()Return the cache name. | 
| ConcurrentMap<Object,Object> | getNativeCache()Return the underlying native cache provider. | 
| boolean | isStoreByValue()Return whether this cache stores a copy of each entry ( true) or
 a reference (false, default). | 
| protected Object | lookup(Object key)Perform an actual lookup in the underlying store. | 
| void | put(Object key,
   Object value)Associate the specified value with the specified key in this cache. | 
| Cache.ValueWrapper | putIfAbsent(Object key,
           Object value)Atomically associate the specified value with the specified key in this cache
 if it is not set already. | 
| protected Object | toStoreValue(Object userValue)Convert the given user value, as passed into the put method,
 to a value in the internal store (adapting  null). | 
get, get, isAllowNullValues, toValueWrapperpublic ConcurrentMapCache(String name)
name - the name of the cachepublic ConcurrentMapCache(String name, boolean allowNullValues)
name - the name of the cacheallowNullValues - whether to accept and convert null
 values for this cachepublic ConcurrentMapCache(String name, ConcurrentMap<Object,Object> store, boolean allowNullValues)
ConcurrentMap to use.name - the name of the cachestore - the ConcurrentMap to use as an internal storeallowNullValues - whether to allow null values
 (adapting them to an internal null holder value)protected ConcurrentMapCache(String name, ConcurrentMap<Object,Object> store, boolean allowNullValues, SerializationDelegate serialization)
ConcurrentMap to use. If the
 SerializationDelegate is specified,
 store-by-value is enabledname - the name of the cachestore - the ConcurrentMap to use as an internal storeallowNullValues - whether to allow null values
 (adapting them to an internal null holder value)serialization - the SerializationDelegate to use
 to serialize cache entry or null to store the referencepublic final boolean isStoreByValue()
true) or
 a reference (false, default). If store by value is enabled, each
 entry in the cache must be serializable.public final String getName()
Cachepublic final ConcurrentMap<Object,Object> getNativeCache()
Cacheprotected Object lookup(Object key)
AbstractValueAdaptingCachelookup in class AbstractValueAdaptingCachekey - the key whose associated value is to be returnedpublic <T> T get(Object key, Callable<T> valueLoader)
CachevalueLoader if necessary. This method provides
 a simple substitute for the conventional "if cached, return; otherwise
 create, cache and return" pattern.
 If possible, implementations should ensure that the loading operation
 is synchronized so that the specified valueLoader is only called
 once in case of concurrent access on the same key.
 
If the valueLoader throws an exception, it is wrapped in
 a Cache.ValueRetrievalException
key - the key whose associated value is to be returnedpublic void put(Object key, Object value)
CacheIf the cache previously contained a mapping for this key, the old value is replaced by the specified value.
key - the key with which the specified value is to be associatedvalue - the value to be associated with the specified keypublic Cache.ValueWrapper putIfAbsent(Object key, Object value)
CacheThis is equivalent to:
 Object existingValue = cache.get(key);
 if (existingValue == null) {
     cache.put(key, value);
     return null;
 } else {
     return existingValue;
 }
 CacheManager implementations are able to perform the put atomically,
 the operation may also be implemented in two steps, e.g. with a check for
 presence and a subsequent put, in a non-atomic way. Check the documentation
 of the native cache implementation that you are using for more details.key - the key with which the specified value is to be associatedvalue - the value to be associated with the specified keynull itself), or also null if the cache did not contain any
 mapping for that key prior to this call. Returning null is therefore
 an indicator that the given value has been associated with the key.public void evict(Object key)
Cachekey - the key whose mapping is to be removed from the cachepublic void clear()
Cacheprotected Object toStoreValue(Object userValue)
AbstractValueAdaptingCachenull).toStoreValue in class AbstractValueAdaptingCacheuserValue - the given user valueprotected Object fromStoreValue(Object storeValue)
AbstractValueAdaptingCachenull).fromStoreValue in class AbstractValueAdaptingCachestoreValue - the store value