Class ReadWriteBackingMap
- java.lang.Object
- 
- java.util.AbstractMap
- 
- com.tangosol.net.cache.ReadWriteBackingMap
 
 
- 
- All Implemented Interfaces:
- CacheMap,- ObservableMap,- Map
 - Direct Known Subclasses:
- ReadWriteSplittingBackingMap,- VersionedBackingMap
 
 public class ReadWriteBackingMap extends AbstractMap implements CacheMap Backing Map implementation that provides a size-limited cache of a persistent store and supports configurable write-behind and refresh- ahead caching. This implementation is not intended to support null keys or null values.- Author:
- cp 2002.11.25, jh 2005.02.08
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description classReadWriteBackingMap.BinaryEntryStoreWrapperA wrapper around the original BinaryEntryStore to allow operations to be overridden and extended.static classReadWriteBackingMap.CacheLoaderCacheStoreA CacheStore wrapped around a CacheLoader.classReadWriteBackingMap.CacheStoreWrapperA wrapper around the original CacheStore to allow operations to be overridden and extended.classReadWriteBackingMap.EntryA queue entry that is scheduled to come out of the front of the queue no earlier than some specific point in time.protected classReadWriteBackingMap.EntrySetA set of entries corresponding to this backing map.static classReadWriteBackingMap.EvictingBackupMapA Map implementation used for a backup map that evicts all data that has been successfully written.protected classReadWriteBackingMap.InternalMapListenerA MapListener implementation that listens to the internal cache and routes those events to anyone listening to this ReadWriteBackingMap.protected classReadWriteBackingMap.KeySetA set of entries backed by this backing map.classReadWriteBackingMap.NonBlockingEntryStoreWrapperA wrapper around the original NonBlockingEntryStore to allow operations to be overridden and extended.protected static classReadWriteBackingMap.ReadLatchA synchronization construct used to coordinate asynchronous loads by the refresh-ahead thread with cache accesses by other threads.classReadWriteBackingMap.ReadQueueA queue of keys that should be read from the underlying CacheStore.classReadWriteBackingMap.ReadThreadA thread that removes keys from aReadWriteBackingMap.ReadQueue, reads the value for the key from the underlying CacheStore, and caches the value in the internal ReadWriteBackingMap cache.classReadWriteBackingMap.StoreWrapperAbstract wrapper around a cache store to allow operations to be overridden and extended.protected classReadWriteBackingMap.ValuesCollectionA collection of values backed by this map.classReadWriteBackingMap.WriteQueueA queue that only releases entries after a configurable period of time.classReadWriteBackingMap.WriteThreadThis is the write-behind thread that pulls things from the write-behind queue and writes them to the CacheStore that the backing map uses.- 
Nested classes/interfaces inherited from class java.util.AbstractMapAbstractMap.SimpleEntry<K extends Object,V extends Object>, AbstractMap.SimpleImmutableEntry<K extends Object,V extends Object>
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static BinaryBIN_ERASE_PENDINGBinary representation of a decorated null for write-behind remove.protected static BinaryBIN_STORE_PENDINGThe binary form of the decoration indicating that the CacheStore on the primary member has not yet written the value.protected static floatGUARD_RECOVERYThe recovery threshold to use for guarded execution of write-behind/refresh-ahead threads.protected MapListenerSupportm_listenerSupportMapListenerSupport object.static longMIN_REQUEUE_DELAYThe minimum "retry after requeue" time interval.static StringPROP_WB_REMOVE_DEFAULTA Boolean system property to control whether write behind remove is enabled.protected static BinaryREMOVEDMarker object used byReadWriteBackingMap.Entryto indicateremovewas called on the Entry.static booleanRWBM_WB_REMOVE_DEFAULTThe default write behind remove behavior.- 
Fields inherited from interface com.tangosol.net.cache.CacheMapEXPIRY_DEFAULT, EXPIRY_NEVER
 
- 
 - 
Constructor SummaryConstructors Constructor Description ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, BinaryEntryStore storeBinary, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor)Construct a ReadWriteBackingMap based on a BinaryEntryStore.ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, BinaryEntryStore storeBinary, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor, boolean fWriteBehindRemove)Construct a ReadWriteBackingMap based on a BinaryEntryStore.ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, CacheLoader loader)Construct a ReadWriteBackingMap based on a CacheLoader (CacheStore).ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, CacheLoader loader, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor)Construct a ReadWriteBackingMap based on a CacheLoader (CacheStore).ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, CacheLoader loader, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor, boolean fWriteBehindRemove)Construct a ReadWriteBackingMap based on a CacheLoader (CacheStore).ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, NonBlockingEntryStore storeBinary, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor)Construct a ReadWriteBackingMap based on a NonBlockingEntryStore.ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, NonBlockingEntryStore storeBinary, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor, boolean fWriteBehindRemove)Construct a ReadWriteBackingMap based on a NonBlockingEntryStore.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddMapListener(MapListener listener)Add a standard map listener that will receive all events (inserts, updates, deletes) that occur against the map, with the key, old-value and new-value included.voidaddMapListener(MapListener listener, Filter filter, boolean fLite)Add a map listener that receives events based on a filter evaluation.voidaddMapListener(MapListener listener, Object oKey, boolean fLite)Add a map listener for a specific key.protected voidcancelOutstandingReads(Object oKey)Cancel any outstanding asynchronous reads for a key.voidclear()Remove everything from the Map.protected voidconfigureCacheStore(ReadWriteBackingMap.StoreWrapper store, boolean fReadOnly, boolean fWBRemove)Set up the StoreWrapper that this backing map will use.protected voidconfigureInternalCache(ObservableMap mapInternal)Configure the internal cache that this backing map uses to store its "in-memory" data.protected voidconfigureReadThread(double dflRefreshAheadFactor)Set up the optional refresh-ahead thread and queue that this backing map will use.protected voidconfigureWriteThread(int cWriteBehindSeconds)Set up the optional write-behind thread and queue that this backing map will use.booleancontainsKey(Object oKey)Returns true if this map contains a mapping for the specified key.booleancontainsValue(Object oValue)Returns true if this CachingMap maps one or more keys to the specified value.SetentrySet()Returns an set view of the mappings contained in this map.booleanequals(Object o)Compares the specified object with this map for equality.protected longextractExpiry(ReadWriteBackingMap.Entry entry)Return the expiration value for the given entry.voidflush()Flush the write-behind queue, writing everything immediately.protected voidflush(ReadWriteBackingMap.WriteQueue queue, ReadWriteBackingMap.StoreWrapper store)Flush the write-behind queue, writing everything immediately.Objectget(Object oKey)Returns the value to which this map maps the specified key.MapgetAll(Collection colKeys)Retrieve values for all the specified keys.protected ObjectgetCachedOrPending(Object oKey)Get a value from the internal cache in a way that respects a potentially pending write-behind operation.CacheServicegetCacheService()Return the CacheService.ReadWriteBackingMap.StoreWrappergetCacheStore()Get the representative of the "persistent" storage for this backing map.longgetCacheStoreTimeoutMillis()Return the timeout used for CacheStore operations, or 0 if no timeout is specified.BackingMapManagerContextgetContext()Get the context information provided by the CacheService.ConcurrentMapgetControlMap()Get the concurrency control map for this backing map.protected ObjectgetFromInternalCache(Object oKey)Get the the value for a given key.ObservableMapgetInternalCache()Get the representative of the "in-memory" storage for this backing map.protected ConfigurableCacheMapgetInternalConfigurableCache()Get the map that provides internal storage for this backing map.protected MapListenergetInternalListener()Obtain the MapListener that listens to the internal cache and routes those events to anyone listening to this ReadWriteBackingMap, creating such a listener if one does not already exist.MapgetMissesCache()Get the optional map used to cache CacheLoader (or CacheStore) misses.SetgetPendingRemoves()Get the pending removes key set for the CacheStore used by this backing map.intgetPendingWrites()Return the size of the write-behind queue if configured, or the number of pending writes of the non-blocking store, if configured.ReadWriteBackingMap.ReadQueuegetReadQueue()Get the queue of keys that are yet to be read.protected ReadWriteBackingMap.ReadThreadgetReadThread()Get the refresh-ahead thread.doublegetRefreshAheadFactor()Return the refresh-ahead factor.protected MapgetSyntheticEventsMap()Get the map of keys for which the events should be marked as synthetic (internal).doublegetWriteBatchFactor()Return the write-batch factor.longgetWriteBehindMillis()Return the number of milliseconds between write-behind writes to the CacheStore or 0 if write-behind is not enabled.intgetWriteBehindSeconds()Return the number of seconds between write-behind writes to the CacheStore or 0 if write-behind is not enabled.intgetWriteMaxBatchSize()Get the maximum size of the write-behind batch.ReadWriteBackingMap.WriteQueuegetWriteQueue()Get the queue of entries that are yet to be written.intgetWriteRequeueThreshold()Return the maximum size of the write-behind queue for which failed CacheStore write operations are requeued or 0 if write-behind requeueing is disabled.protected ReadWriteBackingMap.WriteThreadgetWriteThread()Get the write-behind thread.inthashCode()Returns the hash code value for this map.protected voidheartbeat()Issue a service guardian "heartbeat" for the current thread.protected CacheStoreinstantiateCacheLoaderCacheStore(CacheLoader loader)Factory pattern: Instantiate a CacheLoaderCacheStore wrapper around a passed CacheLoader.protected ReadWriteBackingMap.StoreWrapperinstantiateCacheStoreWrapper(BinaryEntryStore store)Factory pattern: Instantiate a StoreWrapper wrapper around the passed BinaryEntryStore.protected ReadWriteBackingMap.StoreWrapperinstantiateCacheStoreWrapper(CacheStore store)Factory pattern: Instantiate a StoreWrapper wrapper around the passed CacheStore.protected ReadWriteBackingMap.StoreWrapperinstantiateCacheStoreWrapper(NonBlockingEntryStore store)Factory pattern: Instantiate a StoreWrapper wrapper around the passed NonBlockingEntryStore.protected ConcurrentMapinstantiateControlMap()Factory pattern: Create the concurrency control map for this backing map.protected ReadWriteBackingMap.EntryinstantiateEntry(Object oKey, Object oValue, Object oValueOrig)Factory pattern: instantiate a queue entry.protected ReadWriteBackingMap.EntryinstantiateEntry(Object oKey, Object oValue, Object oValueOrig, long cExpiry)Factory pattern: instantiate a queue entry.protected ReadWriteBackingMap.EntrySetinstantiateEntrySet()Factory pattern: instantiate an entry set for this backing map.protected MapListenerinstantiateInternalListener()Factory pattern: Create a MapListener that listens to the internal cache and routes those events to anyone listening to this ReadWriteBackingMap.protected ReadWriteBackingMap.KeySetinstantiateKeySet()Factory pattern: instantiate a key set for this backing map.protected ReadWriteBackingMap.ReadLatchinstantiateReadLatch(Object oKey)Factory pattern: Instantiate a new read latch the given key.protected ReadWriteBackingMap.ReadQueueinstantiateReadQueue()Factory pattern: Instantiate a new ReadQueue object.protected ReadWriteBackingMap.ReadThreadinstantiateReadThread()Factory pattern: Instantiate the refresh-ahead thread.protected ReadWriteBackingMap.ValuesCollectioninstantiateValuesCollection()Factory pattern.protected ReadWriteBackingMap.WriteQueueinstantiateWriteQueue()Factory pattern: Instantiate a new WriteQueue object.protected ReadWriteBackingMap.WriteThreadinstantiateWriteThread()Factory pattern: Instantiate the write-behind thread.booleanisActive()Determine if the backing map is still active.booleanisReadOnly()Determine if the backing map should send data changes through the CacheStore, or should just keep them in memory.booleanisRefreshAhead()Determine if the backing map preemptively reads soon-to-be expired entries on a refresh-ahead thread.booleanisRethrowExceptions()Determine if exceptions caught during synchronous CacheStore operations are rethrown to the calling thread; if false, exceptions are logged.booleanisWriteBehind()Determine if the backing map writes changes on a write-behind thread through the CacheStore.booleanisWriteBehindRemove()Determine if the backing map should apply write-behind delay to remove from CacheStore.booleanisWriteThrough()Determine if the backing map writes changes immediately through the CacheStore.SetkeySet()Returns an set view of the keys contained in this map.Objectput(Object oKey, Object oValue)Associates the specified value with the specified key in this map.Objectput(Object oKey, Object oValue, long cMillis)Associates the specified value with the specified key in this map.voidputAll(Map map)Associates the specified values with the respective keys in this map.protected ObjectputInternal(Object oKey, Object oValue, long cMillis)An actual implementation for the extended put() method.protected voidputToInternalCache(ReadWriteBackingMap.Entry entry)Add the key and value pair to the internal cache in such a way that the resulting map event would be marked as "synthetic".protected voidputToInternalCache(Object oKey, Object oVal)Add the key and value pair to the internal cache in such a way that the resulting map event would be marked as "synthetic".protected voidputToInternalCache(Object oKey, Object oVal, long cMillis)Add the key and value pair to the internal cache in such a way that the resulting map event would be marked as "synthetic".protected ObjectputToInternalMap(Object binKey, Object binValue, long cExpiry)Put the specified key in internal format and value in internal format into the internal backing map.voidrelease()Release the backing map when it is no longer being used.Objectremove(Object oKey)Removes the mapping for this key from this map if present.protected booleanremoveAll(Collection colKeys)Remove the collection of keys from this ReadWriteBackingMap.protected ReadWriteBackingMap.EntryremoveFromWriteQueue(Object binKey)Remove the specified entry from the WriteQueue.protected ObjectremoveInternal(Object oKey, boolean fBlind)Implementation of the remove() API.voidremoveMapListener(MapListener listener)Remove a standard map listener that previously signed up for all events.voidremoveMapListener(MapListener listener, Filter filter)Remove a map listener that previously signed up for events based on a filter evaluation.voidremoveMapListener(MapListener listener, Object oKey)Remove a map listener that previously signed up for events about a specific key.voidsetCacheName(String sCacheName)Set the cache name for ReadThread and WriteThread if not already set.voidsetCacheStoreTimeoutMillis(long cStoreTimeoutMillis)Set the timeout used for CacheStore operations.voidsetRefreshAheadFactor(double dflRefreshAheadFactor)Set the refresh-ahead factor, expressed as a percentage of the internal cache expiration interval.voidsetRethrowExceptions(boolean fRethrow)Set the value of the flag that determines if exceptions caught during synchronous CacheStore operations are rethrown to the calling thread; if false, exceptions are logged.voidsetWriteBatchFactor(double dflWriteBatchFactor)Set the write-batch factor, expressed as a percentage of the write-behind interval.voidsetWriteBehindMillis(long cMillis)Set the number of milliseconds between write-behind writes to the CacheStore.voidsetWriteBehindSeconds(int cSecs)Set the number of seconds between write-behind writes to the CacheStore.voidsetWriteMaxBatchSize(int cWriteMaxBatchSize)Set the maximum size of a batch.voidsetWriteRequeueThreshold(int cThreshold)Set the maximum size of the write-behind queue for which failed CacheStore write operations are requeued.intsize()Returns the number of key-value mappings in this map.protected voidterminateReadThread()Terminate the refresh-ahead thread.protected voidterminateWriteThread()Terminate the write-behind thread.StringtoString()For debugging purposes, format the contents of the Map in a human- readable format.protected voidupdateThreadName(Daemon daemon, String sName)Append the provided name to the Daemon's thread name if not already appended.Collectionvalues()Returns a collection view of the values contained in this map.protected booleanwaitFor(Object o, long cMillis)Wait for notification on the specified object for no longer than the specified wait time.- 
Methods inherited from class java.util.AbstractMapclone, isEmpty
 - 
Methods inherited from class java.lang.Objectfinalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface java.util.Mapcompute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, isEmpty, merge, putIfAbsent, remove, replace, replace, replaceAll
 
- 
 
- 
- 
- 
Field Detail- 
REMOVEDprotected static final Binary REMOVED Marker object used byReadWriteBackingMap.Entryto indicateremovewas called on the Entry.
 - 
BIN_STORE_PENDINGprotected static final Binary BIN_STORE_PENDING The binary form of the decoration indicating that the CacheStore on the primary member has not yet written the value.
 - 
GUARD_RECOVERYprotected static final float GUARD_RECOVERY The recovery threshold to use for guarded execution of write-behind/refresh-ahead threads.- See Also:
- Constant Field Values
 
 - 
MIN_REQUEUE_DELAYpublic static final long MIN_REQUEUE_DELAY The minimum "retry after requeue" time interval. Default value is 60 sec and can be overridden by the system property:coherence.rwbm.requeue.delay 
 - 
BIN_ERASE_PENDINGpublic static final Binary BIN_ERASE_PENDING Binary representation of a decorated null for write-behind remove.- Since:
- 12.2.1.4.18
 
 - 
PROP_WB_REMOVE_DEFAULTpublic static final String PROP_WB_REMOVE_DEFAULT A Boolean system property to control whether write behind remove is enabled.- Since:
- 12.1.4.18
- See Also:
- Constant Field Values
 
 - 
RWBM_WB_REMOVE_DEFAULTpublic static final boolean RWBM_WB_REMOVE_DEFAULT The default write behind remove behavior. This behavior will be used if write behind remove has not been specified in the cache configuration for a RWBM instance. The default value is false and can be overridden by the system property:coherence.rwbm.writebehind.remove.default - Since:
- 12.2.1.4.18
 
 - 
m_listenerSupportprotected MapListenerSupport m_listenerSupport MapListenerSupport object.
 
- 
 - 
Constructor Detail- 
ReadWriteBackingMappublic ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, CacheLoader loader) Construct a ReadWriteBackingMap based on a CacheLoader (CacheStore).- Parameters:
- ctxService- the context provided by the CacheService which is using this backing map
- mapInternal- the ObservableMap used to store the data internally in this backing map
- mapMisses- the Map used to cache CacheLoader misses (optional)
- loader- the CacheLoader responsible for the persistence of the cached data (optional)
 
 - 
ReadWriteBackingMappublic ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, CacheLoader loader, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor) Construct a ReadWriteBackingMap based on a CacheLoader (CacheStore).- Parameters:
- ctxService- the context provided by the CacheService which is using this backing map
- mapInternal- the ObservableMap used to store the data internally in this backing map
- mapMisses- the Map used to cache CacheStore misses (optional)
- loader- the CacheLoader responsible for the persistence of the cached data (optional)
- fReadOnly- pass true is the specified loader is in fact a CacheStore that needs to be used only for read operations; changes to the cache will not be persisted
- cWriteBehindSeconds- number of seconds to write if there is a CacheStore; zero disables write-behind caching, which (combined with !fReadOnly) implies write-through
- dflRefreshAheadFactor- the interval before an entry expiration time (expressed as a percentage of the internal cache expiration interval) during which an asynchronous load request for the entry will be scheduled; zero disables refresh-ahead; only applicable when the mapInternal parameter is an instance of- ConfigurableCacheMap
 
 - 
ReadWriteBackingMappublic ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, CacheLoader loader, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor, boolean fWriteBehindRemove) Construct a ReadWriteBackingMap based on a CacheLoader (CacheStore).- Parameters:
- ctxService- the context provided by the CacheService which is using this backing map
- mapInternal- the ObservableMap used to store the data internally in this backing map
- mapMisses- the Map used to cache CacheStore misses (optional)
- loader- the CacheLoader responsible for the persistence of the cached data (optional)
- fReadOnly- pass true is the specified loader is in fact a CacheStore that needs to be used only for read operations; changes to the cache will not be persisted
- cWriteBehindSeconds- number of seconds to write if there is a CacheStore; zero disables write-behind caching, which (combined with !fReadOnly) implies write-through
- dflRefreshAheadFactor- the interval before an entry expiration time (expressed as a percentage of the internal cache expiration interval) during which an asynchronous load request for the entry will be scheduled; zero disables refresh-ahead; only applicable when the mapInternal parameter is an instance of- ConfigurableCacheMap
- fWriteBehindRemove- pass true if the specified loader is in fact a CacheStore that needs to apply write-behind to remove
- Since:
- 12.2.1.4.18
 
 - 
ReadWriteBackingMappublic ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, BinaryEntryStore storeBinary, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor) Construct a ReadWriteBackingMap based on a BinaryEntryStore.- Parameters:
- ctxService- the context provided by the CacheService which is using this backing map
- mapInternal- the ObservableMap used to store the data internally in this backing map
- mapMisses- the Map used to cache CacheStore misses (optional)
- storeBinary- the BinaryEntryStore responsible for the persistence of the cached data (optional)
- fReadOnly- pass true is the specified loader is in fact a CacheStore that needs to be used only for read operations; changes to the cache will not be persisted
- cWriteBehindSeconds- number of seconds to write if there is a CacheStore; zero disables write-behind caching, which (combined with !fReadOnly) implies write-through
- dflRefreshAheadFactor- the interval before an entry expiration time (expressed as a percentage of the internal cache expiration interval) during which an asynchronous load request for the entry will be scheduled; zero disables refresh-ahead; only applicable when the mapInternal parameter is an instance of- ConfigurableCacheMap
- Since:
- Coherence 3.6
 
 - 
ReadWriteBackingMappublic ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, BinaryEntryStore storeBinary, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor, boolean fWriteBehindRemove) Construct a ReadWriteBackingMap based on a BinaryEntryStore.- Parameters:
- ctxService- the context provided by the CacheService which is using this backing map
- mapInternal- the ObservableMap used to store the data internally in this backing map
- mapMisses- the Map used to cache CacheStore misses (optional)
- storeBinary- the BinaryEntryStore responsible for the persistence of the cached data (optional)
- fReadOnly- pass true is the specified loader is in fact a CacheStore that needs to be used only for read operations; changes to the cache will not be persisted
- cWriteBehindSeconds- number of seconds to write if there is a CacheStore; zero disables write-behind caching, which (combined with !fReadOnly) implies write-through
- dflRefreshAheadFactor- the interval before an entry expiration time (expressed as a percentage of the internal cache expiration interval) during which an asynchronous load request for the entry will be scheduled; zero disables refresh-ahead; only applicable when the mapInternal parameter is an instance of- ConfigurableCacheMap
- fWriteBehindRemove- pass true if the specified loader is in fact a CacheStore that needs to apply write-behind to remove
- Since:
- 12.2.1.4.18
 
 - 
ReadWriteBackingMappublic ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, NonBlockingEntryStore storeBinary, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor) Construct a ReadWriteBackingMap based on a NonBlockingEntryStore.- Parameters:
- ctxService- the context provided by the CacheService which is using this backing map
- mapInternal- the ObservableMap used to store the data internally in this backing map
- mapMisses- the Map used to cache CacheStore misses (optional)
- storeBinary- the NonBlockingEntryStore responsible for the persistence of the cached data (optional)
- fReadOnly- pass true is the specified loader is in fact a CacheStore that needs to be used only for read operations; changes to the cache will not be persisted
- cWriteBehindSeconds- number of seconds to write if there is a CacheStore; zero disables write-behind caching, which (combined with !fReadOnly) implies write-through
- dflRefreshAheadFactor- the interval before an entry expiration time (expressed as a percentage of the internal cache expiration interval) during which an asynchronous load request for the entry will be scheduled; zero disables refresh-ahead; only applicable when the mapInternal parameter is an instance of- ConfigurableCacheMap
- Since:
- Coherence 21.06
 
 - 
ReadWriteBackingMappublic ReadWriteBackingMap(BackingMapManagerContext ctxService, ObservableMap mapInternal, Map mapMisses, NonBlockingEntryStore storeBinary, boolean fReadOnly, int cWriteBehindSeconds, double dflRefreshAheadFactor, boolean fWriteBehindRemove) Construct a ReadWriteBackingMap based on a NonBlockingEntryStore.- Parameters:
- ctxService- the context provided by the CacheService which is using this backing map
- mapInternal- the ObservableMap used to store the data internally in this backing map
- mapMisses- the Map used to cache CacheStore misses (optional)
- storeBinary- the NonBlockingEntryStore responsible for the persistence of the cached data (optional)
- fReadOnly- pass true is the specified loader is in fact a CacheStore that needs to be used only for read operations; changes to the cache will not be persisted
- cWriteBehindSeconds- number of seconds to write if there is a CacheStore; zero disables write-behind caching, which (combined with !fReadOnly) implies write-through
- dflRefreshAheadFactor- the interval before an entry expiration time (expressed as a percentage of the internal cache expiration interval) during which an asynchronous load request for the entry will be scheduled; zero disables refresh-ahead; only applicable when the mapInternal parameter is an instance of- ConfigurableCacheMap
- fWriteBehindRemove- pass true if the specified loader is in fact a CacheStore that needs to apply write-behind to remove
- Since:
- 12.2.1.4.18
 
 
- 
 - 
Method Detail- 
getContextpublic BackingMapManagerContext getContext() Get the context information provided by the CacheService.- Returns:
- the CacheService's BackingMapManagerContext object that it provided to the BackingMapManager that created this backing map
 
 - 
getCacheServicepublic CacheService getCacheService() Return the CacheService.- Returns:
- the CacheService
 
 - 
isRethrowExceptionspublic boolean isRethrowExceptions() Determine if exceptions caught during synchronous CacheStore operations are rethrown to the calling thread; if false, exceptions are logged.- Returns:
- true if CacheStore exceptions are rethrown to the calling thread
 
 - 
setRethrowExceptionspublic void setRethrowExceptions(boolean fRethrow) Set the value of the flag that determines if exceptions caught during synchronous CacheStore operations are rethrown to the calling thread; if false, exceptions are logged.- Parameters:
- fRethrow- true to indicate that exceptions should be rethrown
 
 - 
getRefreshAheadFactorpublic double getRefreshAheadFactor() Return the refresh-ahead factor.The refresh-ahead factor is used to calculate the "soft-expiration" time for cache entries. Soft-expiration is the point in time prior to the actual expiration after which any access request for an entry will schedule an asynchronous load request for the entry. The value of this property is expressed as a percentage of the internal cache expiration interval. If zero, refresh-ahead scheduling is disabled. - Returns:
- the refresh-ahead factor
 
 - 
setRefreshAheadFactorpublic void setRefreshAheadFactor(double dflRefreshAheadFactor) Set the refresh-ahead factor, expressed as a percentage of the internal cache expiration interval. Valid values are doubles in the interval [0.0, 1.0].This method has no effect if refresh-ahead is disabled. - Parameters:
- dflRefreshAheadFactor- the new refresh-ahead factor
- See Also:
- getRefreshAheadFactor()
 
 - 
isReadOnlypublic boolean isReadOnly() Determine if the backing map should send data changes through the CacheStore, or should just keep them in memory.- Returns:
- false to send changes to CacheStore (a read-write cache), or true to just keep them in memory (a read-only cache)
 
 - 
isRefreshAheadpublic boolean isRefreshAhead() Determine if the backing map preemptively reads soon-to-be expired entries on a refresh-ahead thread.- Returns:
- true if refresh-ahead is enabled
 
 - 
getWriteMaxBatchSizepublic int getWriteMaxBatchSize() Get the maximum size of the write-behind batch.- Returns:
- the maximum number of entries in the write-behind batch
 
 - 
setWriteMaxBatchSizepublic void setWriteMaxBatchSize(int cWriteMaxBatchSize) Set the maximum size of a batch. The size is used to reduce the size of the write-behind batches and the amount of [scratch] memory used to keep de-serialized entries passed to the storeAll operations.This method has no effect if write-behind is disabled. - Parameters:
- cWriteMaxBatchSize- the maximum batch size
 
 - 
getWriteBatchFactorpublic double getWriteBatchFactor() Return the write-batch factor.The write-batch factor is used to calculate the "soft-ripe" time for write-behind queue entries. A queue entry is considered to be "ripe" for a write operation if it has been in the write-behind queue for no less than the write-behind interval. The "soft-ripe" time is the point in time prior to the actual ripe time after which an entry will be included in a batched asynchronous write operation to the CacheStore (along with all other ripe and soft-ripe entries). In other words, a soft-ripe entry is an entry that has been in the write-behind queue for at least the following duration: D' = (1.0 - F)*D where:D = write-behind delay F = write-batch factor Conceptually, the write-behind thread uses the following logic when performing a batched update:- The thread waits for a queued entry to become ripe.
- When an entry becomes ripe, the thread dequeues all ripe and soft-ripe entries in the queue.
- The thread then writes all ripe and soft-ripe entries either via
     store()(if there is only the single ripe entry) orstoreAll()(if there are multiple ripe/soft-ripe entries).
- The thread then repeats (1).
 This property is only applicable if asynchronous writes are enabled and the CacheStore implements the storeAll()method.The value of this property is expressed as a percentage of the write-behindinterval. Valid values are doubles in the interval [0.0, 1.0].- Returns:
- the write-batch factor
 
 - 
setWriteBatchFactorpublic void setWriteBatchFactor(double dflWriteBatchFactor) Set the write-batch factor, expressed as a percentage of the write-behind interval. Valid values are doubles in the interval [0.0, 1.0].This method has no effect if write-behind is disabled. - Parameters:
- dflWriteBatchFactor- the new write-batch factor
- See Also:
- getWriteBatchFactor()
 
 - 
isWriteBehindpublic boolean isWriteBehind() Determine if the backing map writes changes on a write-behind thread through the CacheStore.- Returns:
- true implies changes are queued to be written asynchronously
 
 - 
getWriteBehindSecondspublic int getWriteBehindSeconds() Return the number of seconds between write-behind writes to the CacheStore or 0 if write-behind is not enabled.- Returns:
- the number of seconds between write-behind writes
 
 - 
setWriteBehindSecondspublic void setWriteBehindSeconds(int cSecs) Set the number of seconds between write-behind writes to the CacheStore.This method has not effect if write-behind is not enabled. - Parameters:
- cSecs- the new write-behind delay in seconds
 
 - 
getWriteBehindMillispublic long getWriteBehindMillis() Return the number of milliseconds between write-behind writes to the CacheStore or 0 if write-behind is not enabled.- Returns:
- the number of milliseconds between write-behind writes
- Since:
- Coherence 3.4
 
 - 
setWriteBehindMillispublic void setWriteBehindMillis(long cMillis) Set the number of milliseconds between write-behind writes to the CacheStore.This method has not effect if write-behind is not enabled. - Parameters:
- cMillis- the new write-behind delay in milliseconds
- Since:
- Coherence 3.4
 
 - 
getWriteRequeueThresholdpublic int getWriteRequeueThreshold() Return the maximum size of the write-behind queue for which failed CacheStore write operations are requeued or 0 if write-behind requeueing is disabled.- Returns:
- the write-behind requeue threshold
 
 - 
setWriteRequeueThresholdpublic void setWriteRequeueThreshold(int cThreshold) Set the maximum size of the write-behind queue for which failed CacheStore write operations are requeued.This method has not effect if write-behind is not enabled. - Parameters:
- cThreshold- the new write-behind requeue threshold
 
 - 
isWriteThroughpublic boolean isWriteThrough() Determine if the backing map writes changes immediately through the CacheStore.- Returns:
- true implies that changes to the backing map are written synchronously to the CacheStore
 
 - 
getCacheStoreTimeoutMillispublic long getCacheStoreTimeoutMillis() Return the timeout used for CacheStore operations, or 0 if no timeout is specified.- Returns:
- the CacheStore timeout
 
 - 
setCacheStoreTimeoutMillispublic void setCacheStoreTimeoutMillis(long cStoreTimeoutMillis) Set the timeout used for CacheStore operations. A value of 0 indicates to use the default guardian timeout of the associated service.- Parameters:
- cStoreTimeoutMillis- the CacheStore timeout, or 0 for the default guardian timeout
 
 - 
setCacheNamepublic void setCacheName(String sCacheName) Set the cache name for ReadThread and WriteThread if not already set.- Parameters:
- sCacheName- the name of the cache
 
 - 
getPendingWritespublic int getPendingWrites() Return the size of the write-behind queue if configured, or the number of pending writes of the non-blocking store, if configured. Return -1 if neither.- Returns:
- number of pending writes
 
 - 
isWriteBehindRemovepublic boolean isWriteBehindRemove() Determine if the backing map should apply write-behind delay to remove from CacheStore.- Returns:
- true to delay the remove from CacheStore (a read-write cache), or false to remove from CacheStore immediately
- Since:
- 12.2.1.4.18
 
 - 
clearpublic void clear() Remove everything from the Map.- Specified by:
- clearin interface- Map
- Overrides:
- clearin class- AbstractMap
 
 - 
containsKeypublic boolean containsKey(Object oKey) Returns true if this map contains a mapping for the specified key.- Specified by:
- containsKeyin interface- Map
- Overrides:
- containsKeyin class- AbstractMap
- Parameters:
- oKey- the key to test for
- Returns:
- true if this map contains a mapping for the specified key, false otherwise.
 
 - 
containsValuepublic boolean containsValue(Object oValue) Returns true if this CachingMap maps one or more keys to the specified value.- Specified by:
- containsValuein interface- Map
- Overrides:
- containsValuein class- AbstractMap
- Parameters:
- oValue- the value to test for
- Returns:
- true if this CachingMap maps one or more keys to the specified value, false otherwise
 
 - 
getpublic Object get(Object oKey) Returns the value to which this map maps the specified key.- Specified by:
- getin interface- Map
- Overrides:
- getin class- AbstractMap
- Parameters:
- oKey- the key object
- Returns:
- the value to which this map maps the specified key, or null if the map contains no mapping for this key
 
 - 
putpublic Object put(Object oKey, Object oValue) Associates the specified value with the specified key in this map.- Specified by:
- putin interface- CacheMap
- Specified by:
- putin interface- Map
- Overrides:
- putin class- AbstractMap
- Parameters:
- oKey- key with which the specified value is to be associated
- oValue- value to be associated with the specified key
- Returns:
- previous value associated with specified key, or null if there was no mapping for key. A null return can also indicate that the map previously associated null with the specified key, if the implementation supports null values.
 
 - 
removepublic Object remove(Object oKey) Removes the mapping for this key from this map if present. Expensive: updates both the underlying cache and the local cache.- Specified by:
- removein interface- Map
- Overrides:
- removein class- AbstractMap
- Parameters:
- oKey- key whose mapping is to be removed from the map
- Returns:
- previous value associated with specified key, or null if there was no mapping for key. A null return can also indicate that the map previously associated null with the specified key, if the implementation supports null values.
 
 - 
putAllpublic void putAll(Map map) Associates the specified values with the respective keys in this map. Be aware that the keys will be locked in the order they are returned from iterating over the map passed in and unlocked at the end of the method. This method is called internally within Coherence and the keys will have been locked at the Service level already, so concurrent calls to this method with the same keys will not be an issue. If this method is somehow called directly by application code, which is not recommended, then it is advisable to pass in a sorted map that sorts the keys by their natural ordering.- Specified by:
- putAllin interface- Map
- Overrides:
- putAllin class- AbstractMap
- Parameters:
- map- keys and values which are to be associated in this map
 
 - 
putToInternalMapprotected Object putToInternalMap(Object binKey, Object binValue, long cExpiry) Put the specified key in internal format and value in internal format into the internal backing map. If the cExpiry parameter is greater than the default expiry value CacheMap.EXPIRY_DEFAULT and the internal map is not an instance ofCacheMapthen an exception will be thrown.- Parameters:
- binKey- the key in internal format
- binValue- the value in internal format; null if the value should be cached as "missing"
- cExpiry- the cache entry expiry value
- Returns:
- any previous value tht was mapped to the key.
- Throws:
- UnsupportedOperationException- if the value of cExpiry is greater than CacheMap.EXPIRY_DEFAULT and the internal map is not an instance of- CacheMap.
 
 - 
removeInternalprotected Object removeInternal(Object oKey, boolean fBlind) Implementation of the remove() API.- Parameters:
- oKey- key whose mapping is to be removed from the map
- fBlind- if true, the return value will be ignored
- Returns:
- previous value associated with specified key, or null
 
 - 
sizepublic int size() Returns the number of key-value mappings in this map. If the map contains more than Integer.MAX_VALUE elements, returns Integer.MAX_VALUE.- Specified by:
- sizein interface- Map
- Overrides:
- sizein class- AbstractMap
- Returns:
- the number of key-value mappings in this map
 
 - 
entrySetpublic Set entrySet() Returns an set view of the mappings contained in this map.- Specified by:
- entrySetin interface- Map
- Specified by:
- entrySetin class- AbstractMap
- Returns:
- a set view of the mappings contained in this map
 
 - 
keySetpublic Set keySet() Returns an set view of the keys contained in this map.- Specified by:
- keySetin interface- Map
- Overrides:
- keySetin class- AbstractMap
- Returns:
- a set view of the keys contained in this map
 
 - 
valuespublic Collection values() Returns a collection view of the values contained in this map.- Specified by:
- valuesin interface- Map
- Overrides:
- valuesin class- AbstractMap
- Returns:
- a collection view of the values contained in this map
 
 - 
putpublic Object put(Object oKey, Object oValue, long cMillis) Associates the specified value with the specified key in this map.- Specified by:
- putin interface- CacheMap
- Parameters:
- oKey- key with which the specified value is to be associated
- oValue- value to be associated with the specified key
- cMillis- the number of milliseconds until the entry will expire; pass zero to use the cache's default ExpiryDelay settings; pass -1 to indicate that the entry should never expire
- Returns:
- previous value associated with specified key, or null if there was no mapping for key
 
 - 
getAllpublic Map getAll(Collection colKeys) Retrieve values for all the specified keys.
 - 
removeAllprotected boolean removeAll(Collection colKeys) Remove the collection of keys from this ReadWriteBackingMap.This method will ensure the configured CacheStore.eraseAll method is called with all owned keys in addition to removing the relevant entries from the internal Map. - Parameters:
- colKeys- a collection of keys to remove, that may be in the map
- Returns:
- true if any of the provided keys were successfully removed from this map
 
 - 
putToInternalCacheprotected void putToInternalCache(Object oKey, Object oVal) Add the key and value pair to the internal cache in such a way that the resulting map event would be marked as "synthetic".- Parameters:
- oKey- the key in internal format
- oVal- the value in internal format; null if the value should be cached as "missing"
 
 - 
putToInternalCacheprotected void putToInternalCache(ReadWriteBackingMap.Entry entry) Add the key and value pair to the internal cache in such a way that the resulting map event would be marked as "synthetic".- Parameters:
- entry- cache entry
 
 - 
putToInternalCacheprotected void putToInternalCache(Object oKey, Object oVal, long cMillis) Add the key and value pair to the internal cache in such a way that the resulting map event would be marked as "synthetic".- Parameters:
- oKey- the key in internal format
- oVal- the value in internal format; null if the value should be cached as "missing"
- cMillis- the cache entry expiry value
 
 - 
cancelOutstandingReadsprotected void cancelOutstandingReads(Object oKey) Cancel any outstanding asynchronous reads for a key.- Parameters:
- oKey- the key in internal format
 
 - 
getFromInternalCacheprotected Object getFromInternalCache(Object oKey) Get the the value for a given key. If the entry is present in the internal cache and refresh-ahead is configured, check if a reload operation needs to be scheduled. If the entry is missing, check for a potentially pending refresh-ahead operation and potentially pending write-behind.- Parameters:
- oKey- the key in internal format
- Returns:
- the value or null if the value is not found
 
 - 
getCachedOrPendingprotected Object getCachedOrPending(Object oKey) Get a value from the internal cache in a way that respects a potentially pending write-behind operation.- Parameters:
- oKey- the key
- Returns:
- the corresponding value
 
 - 
putInternalprotected Object putInternal(Object oKey, Object oValue, long cMillis) An actual implementation for the extended put() method.- Parameters:
- oKey- key with which the specified value is to be associated
- oValue- value to be associated with the specified key
- cMillis- the number of milliseconds until the entry will expire
- Returns:
- previous value associated with specified key, or null if there was no mapping for key.
 
 - 
waitForprotected boolean waitFor(Object o, long cMillis) Wait for notification on the specified object for no longer than the specified wait time.Note: the caller must hold synchronization on the object being waited on. - Parameters:
- o- the object to wait for notification on
- cMillis- the maximum time in milliseconds to wait; pass 0 for forever
- Returns:
- true iff notification was received, the timeout has passed, or the thread was spuriously wakened; false if this thread was interrupted
 
 - 
heartbeatprotected void heartbeat() Issue a service guardian "heartbeat" for the current thread.
 - 
extractExpiryprotected long extractExpiry(ReadWriteBackingMap.Entry entry) Return the expiration value for the given entry.- Parameters:
- entry- the entry
- Returns:
- the expiration value
 
 - 
updateThreadNameprotected void updateThreadName(Daemon daemon, String sName) Append the provided name to the Daemon's thread name if not already appended.- Parameters:
- daemon- the Daemon to be modified
- sName- the name to append to the Daemon's thread name
 
 - 
instantiateEntrySetprotected ReadWriteBackingMap.EntrySet instantiateEntrySet() Factory pattern: instantiate an entry set for this backing map.- Returns:
- a new EntrySet object
 
 - 
instantiateKeySetprotected ReadWriteBackingMap.KeySet instantiateKeySet() Factory pattern: instantiate a key set for this backing map.- Returns:
- a new KeySet object
 
 - 
instantiateValuesCollectionprotected ReadWriteBackingMap.ValuesCollection instantiateValuesCollection() Factory pattern.- Returns:
- a new instance of the ValuesCollection class (or subclass thereof)
 
 - 
addMapListenerpublic void addMapListener(MapListener listener) Add a standard map listener that will receive all events (inserts, updates, deletes) that occur against the map, with the key, old-value and new-value included. This has the same result as the following call:addMapListener(listener, (Filter) null, false); - Specified by:
- addMapListenerin interface- ObservableMap
- Parameters:
- listener- the- MapEventlistener to add
 
 - 
removeMapListenerpublic void removeMapListener(MapListener listener) Remove a standard map listener that previously signed up for all events. This has the same result as the following call:removeMapListener(listener, (Filter) null); - Specified by:
- removeMapListenerin interface- ObservableMap
- Parameters:
- listener- the listener to remove
 
 - 
addMapListenerpublic void addMapListener(MapListener listener, Object oKey, boolean fLite) Add a map listener for a specific key.The listeners will receive MapEvent objects, but if fLite is passed as true, they might not contain the OldValue and NewValue properties. To unregister the MapListener, use the ObservableMap.removeMapListener(MapListener, Object)method.- Specified by:
- addMapListenerin interface- ObservableMap
- Parameters:
- listener- the- MapEventlistener to add
- oKey- the key that identifies the entry for which to raise events
- fLite- true to indicate that the- MapEventobjects do not have to include the OldValue and NewValue property values in order to allow optimizations
 
 - 
removeMapListenerpublic void removeMapListener(MapListener listener, Object oKey) Remove a map listener that previously signed up for events about a specific key.- Specified by:
- removeMapListenerin interface- ObservableMap
- Parameters:
- listener- the listener to remove
- oKey- the key that identifies the entry for which to raise events
 
 - 
addMapListenerpublic void addMapListener(MapListener listener, Filter filter, boolean fLite) Add a map listener that receives events based on a filter evaluation.The listeners will receive MapEvent objects, but if fLite is passed as true, they might not contain the OldValue and NewValue properties. To unregister the MapListener, use the ObservableMap.removeMapListener(MapListener, Filter)method.- Specified by:
- addMapListenerin interface- ObservableMap
- Parameters:
- listener- the- MapEventlistener to add
- filter- a filter that will be passed MapEvent objects to select from; a MapEvent will be delivered to the listener only if the filter evaluates to true for that MapEvent (see- MapEventFilter); null is equivalent to a filter that alway returns true
- fLite- true to indicate that the- MapEventobjects do not have to include the OldValue and NewValue property values in order to allow optimizations
 
 - 
removeMapListenerpublic void removeMapListener(MapListener listener, Filter filter) Remove a map listener that previously signed up for events based on a filter evaluation.- Specified by:
- removeMapListenerin interface- ObservableMap
- Parameters:
- listener- the listener to remove
- filter- the filter that was passed into the corresponding addMapListener() call
 
 - 
equalspublic boolean equals(Object o) Compares the specified object with this map for equality. Returns true if the given object is also a map and the two maps represent the same mappings.- Specified by:
- equalsin interface- Map
- Overrides:
- equalsin class- AbstractMap
- Parameters:
- o- object to be compared for equality with this map
- Returns:
- true if the specified object is equal to this map
 
 - 
hashCodepublic int hashCode() Returns the hash code value for this map.- Specified by:
- hashCodein interface- Map
- Overrides:
- hashCodein class- AbstractMap
- Returns:
- the hash code value for this map
 
 - 
toStringpublic String toString() For debugging purposes, format the contents of the Map in a human- readable format.- Overrides:
- toStringin class- AbstractMap
- Returns:
- a String representation of this ReadWriteBackingMap
 
 - 
getInternalCachepublic ObservableMap getInternalCache() Get the representative of the "in-memory" storage for this backing map.- Returns:
- the ObservableMap object (never null) that this backing map uses to store entries
 
 - 
getInternalConfigurableCacheprotected ConfigurableCacheMap getInternalConfigurableCache() Get the map that provides internal storage for this backing map. If the internal storage is a ConfigurableCacheMap, then this accessor returns the same reference asgetInternalCache(); otherwise it returns null. The refresh-ahead implementation relies on the internal storage providing the ConfigurableCacheMap interface, so this method will always return a non-null value if refresh-ahead is enabled.- Returns:
- the cache for this backing map or null if the internal map is not an implementation of the ConfigurableCacheMap interface
 
 - 
configureInternalCacheprotected void configureInternalCache(ObservableMap mapInternal) Configure the internal cache that this backing map uses to store its "in-memory" data.- Parameters:
- mapInternal- the internal map
 
 - 
getMissesCachepublic Map getMissesCache() Get the optional map used to cache CacheLoader (or CacheStore) misses.- Returns:
- the Map that this backing map uses to cache CacheLoader (or CacheStore) misses or null if misses are not cached
 
 - 
getPendingRemovespublic Set getPendingRemoves() Get the pending removes key set for the CacheStore used by this backing map.- Returns:
- the key set of pending removes for the CacheStore
- Since:
- 12.2.1.4.18
 
 - 
getControlMappublic ConcurrentMap getControlMap() Get the concurrency control map for this backing map.- Returns:
- the ObservableMap object (never null) that this backing map uses to store entries
 
 - 
instantiateControlMapprotected ConcurrentMap instantiateControlMap() Factory pattern: Create the concurrency control map for this backing map.- Returns:
- a new concurrency control map
 
 - 
getSyntheticEventsMapprotected Map getSyntheticEventsMap() Get the map of keys for which the events should be marked as synthetic (internal).- Returns:
- the map of keys to mark events as internal
 
 - 
getInternalListenerprotected MapListener getInternalListener() Obtain the MapListener that listens to the internal cache and routes those events to anyone listening to this ReadWriteBackingMap, creating such a listener if one does not already exist.- Returns:
- a routing MapListener
 
 - 
instantiateInternalListenerprotected MapListener instantiateInternalListener() Factory pattern: Create a MapListener that listens to the internal cache and routes those events to anyone listening to this ReadWriteBackingMap.- Returns:
- a new routing MapListener
 
 - 
releasepublic void release() Release the backing map when it is no longer being used.
 - 
isActivepublic boolean isActive() Determine if the backing map is still active.- Returns:
- true if the backing map is still active
 
 - 
instantiateReadLatchprotected ReadWriteBackingMap.ReadLatch instantiateReadLatch(Object oKey) Factory pattern: Instantiate a new read latch the given key.- Parameters:
- oKey- the key
- Returns:
- the read latch
 
 - 
getReadQueuepublic ReadWriteBackingMap.ReadQueue getReadQueue() Get the queue of keys that are yet to be read.- Returns:
- the refresh-ahead queue object
 
 - 
instantiateReadQueueprotected ReadWriteBackingMap.ReadQueue instantiateReadQueue() Factory pattern: Instantiate a new ReadQueue object.- Returns:
- a new ReadQueue object
 
 - 
getWriteQueuepublic ReadWriteBackingMap.WriteQueue getWriteQueue() Get the queue of entries that are yet to be written.- Returns:
- the write-behind queue object
 
 - 
flushpublic void flush() Flush the write-behind queue, writing everything immediately.
 - 
flushprotected void flush(ReadWriteBackingMap.WriteQueue queue, ReadWriteBackingMap.StoreWrapper store) Flush the write-behind queue, writing everything immediately.- Parameters:
- queue- the write-behind queue to flush
- store- the CacheStore to flush to
 
 - 
removeFromWriteQueueprotected ReadWriteBackingMap.Entry removeFromWriteQueue(Object binKey) Remove the specified entry from the WriteQueue.- Parameters:
- binKey- the key
- Returns:
- the currently queued entry (could be NO_VALUE marker or null)
 
 - 
instantiateEntryprotected ReadWriteBackingMap.Entry instantiateEntry(Object oKey, Object oValue, Object oValueOrig) Factory pattern: instantiate a queue entry.- Parameters:
- oKey- the key for the new entry
- oValue- the entry's value; could be null representing a non-existing or removed entry
- oValueOrig- the entry's original value; could be null representing a non-existing entry
- Returns:
- a new Entry
 
 - 
instantiateEntryprotected ReadWriteBackingMap.Entry instantiateEntry(Object oKey, Object oValue, Object oValueOrig, long cExpiry) Factory pattern: instantiate a queue entry.- Parameters:
- oKey- the key for the new entry
- oValue- the entry's value; could be null representing a non-existing or removed entry
- oValueOrig- the entry's original value; could be null representing a non-existing entry
- cExpiry- the expiry delay, or- CacheMap.EXPIRY_NEVERor- CacheMap.EXPIRY_DEFAULT
- Returns:
- a new Entry
 
 - 
instantiateWriteQueueprotected ReadWriteBackingMap.WriteQueue instantiateWriteQueue() Factory pattern: Instantiate a new WriteQueue object.- Returns:
- a new WriteQueue object
 
 - 
getReadThreadprotected ReadWriteBackingMap.ReadThread getReadThread() Get the refresh-ahead thread.- Returns:
- the refresh-ahead thread or null if refresh-ahead is not enabled
 
 - 
configureReadThreadprotected void configureReadThread(double dflRefreshAheadFactor) Set up the optional refresh-ahead thread and queue that this backing map will use.This method has no effect if the given refresh-ahead factor is zero or the cache returned by getInternalConfigurableCache()is null or non-expiring.- Parameters:
- dflRefreshAheadFactor- the refresh-ahead factor expressed as a percentage of the internal cache expiry
 
 - 
instantiateReadThreadprotected ReadWriteBackingMap.ReadThread instantiateReadThread() Factory pattern: Instantiate the refresh-ahead thread.- Returns:
- a new refresh-ahead thread
 
 - 
terminateReadThreadprotected void terminateReadThread() Terminate the refresh-ahead thread.
 - 
getWriteThreadprotected ReadWriteBackingMap.WriteThread getWriteThread() Get the write-behind thread.- Returns:
- the write-behind thread or null if there is no CacheStore to write to
 
 - 
configureWriteThreadprotected void configureWriteThread(int cWriteBehindSeconds) Set up the optional write-behind thread and queue that this backing map will use.This method has no effect if the given write-behind delay is zero or isReadOnly()returns true.- Parameters:
- cWriteBehindSeconds- write-behind delay
 
 - 
instantiateWriteThreadprotected ReadWriteBackingMap.WriteThread instantiateWriteThread() Factory pattern: Instantiate the write-behind thread.- Returns:
- a new write-behind thread
 
 - 
terminateWriteThreadprotected void terminateWriteThread() Terminate the write-behind thread.
 - 
getCacheStorepublic ReadWriteBackingMap.StoreWrapper getCacheStore() Get the representative of the "persistent" storage for this backing map.- Returns:
- the cache store wrapper object that this backing map uses for persistence or null if there is no persistent store behind this backing map
 
 - 
configureCacheStoreprotected void configureCacheStore(ReadWriteBackingMap.StoreWrapper store, boolean fReadOnly, boolean fWBRemove) Set up the StoreWrapper that this backing map will use.- Parameters:
- store- the StoreWrapper that this backing map will delegate persistence responsibilities to
- fReadOnly- pass true to prevent the usage of the cache store write operations
- fWBRemove- pass true to apply write-behind to remove
 
 - 
instantiateCacheStoreWrapperprotected ReadWriteBackingMap.StoreWrapper instantiateCacheStoreWrapper(CacheStore store) Factory pattern: Instantiate a StoreWrapper wrapper around the passed CacheStore. (Supports CacheStore extension by delegation pattern.)- Parameters:
- store- the CacheStore to wrap
- Returns:
- the StoreWrapper wrapper that can supplement and override the operations of the supplied CacheStore
 
 - 
instantiateCacheStoreWrapperprotected ReadWriteBackingMap.StoreWrapper instantiateCacheStoreWrapper(BinaryEntryStore store) Factory pattern: Instantiate a StoreWrapper wrapper around the passed BinaryEntryStore. (Supports BinaryEntryStore extension by delegation pattern.)- Parameters:
- store- the BinaryEntryStore to wrap
- Returns:
- the StoreWrapper wrapper that can supplement and override the operations of the supplied BinaryEntryStore
 
 - 
instantiateCacheStoreWrapperprotected ReadWriteBackingMap.StoreWrapper instantiateCacheStoreWrapper(NonBlockingEntryStore store) Factory pattern: Instantiate a StoreWrapper wrapper around the passed NonBlockingEntryStore. (Supports NonBlockingEntryStore extension by delegation pattern.)- Parameters:
- store- the NonBlockingEntryStore to wrap
- Returns:
- the StoreWrapper wrapper that can supplement and override the operations of the supplied BinaryEntryStore
 
 - 
instantiateCacheLoaderCacheStoreprotected CacheStore instantiateCacheLoaderCacheStore(CacheLoader loader) Factory pattern: Instantiate a CacheLoaderCacheStore wrapper around a passed CacheLoader.- Parameters:
- loader- the CacheLoader to wrap; never null
- Returns:
- a CacheStore instance
 
 
- 
 
-