Class SimpleOverflowMap
- All Implemented Interfaces:
- Map
 The SimpleOverflowMap is not observable, and as such it is assumed to be
 a passive data structure. In other words, it does not support item
 expiration or other types of "self-generating" events. As such, it may
 be more efficient for many common use cases that would benefit from the
 complete avoidance of event handling. As a second effect of being a passive
 data structure, the implementation is able to avoid tracking all of its
 entries; instead it tracks only entries that are in the front map and those
 that currently have a pending event or an in-flight operation occurring.
 This means that huge key sets are possible, since only keys in the front
 map will be managed in memory by the overflow map, but it means that some
 operations that would benefit from knowing the entire set of keys will be
 more expensive. Examples of operations that would be less efficient as a
 result include containsKey(), size(),
 keySet().iterator(), etc.
- Since:
- Coherence 3.1
- Author:
- cp 2005.07.11
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionprotected static classA combination Filter and Converter used to iterate through the status map in order to iterate through the front keys.protected classA listener for the front map that moves evictions to the back map.protected static classA stateless Comparator that comparesObject.hashCode()values.protected classAn Iterator implementation that attempts to provide the most resilient and most up-to-date view of the keys in the OverflowMap.protected static classThe Status object is used to manage concurrency at the key level for the key-level operations against the Map, to track all the items in the front Map, to manage the state transition for operations occurring against the Map, and to coordinate events across multiple threads.Nested classes/interfaces inherited from class com.tangosol.util.AbstractKeyBasedMapAbstractKeyBasedMap.DeferredCacheEvent<K,V>, AbstractKeyBasedMap.EntrySet, AbstractKeyBasedMap.KeySet, AbstractKeyBasedMap.ValuesCollection Nested classes/interfaces inherited from class com.tangosol.util.BaseBase.LoggingWriter
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final intThis event indicates that an entry has been removed from the map.static final intThis event indicates that an entry has been added to the map.static final intThis event indicates that an entry has been updated in the map.protected MapThe "back" map, which the front overflows to.protected ObservableMapThe "front" map, which is size-limited.protected MapThe miss cache; may be null.protected SimpleCacheStatisticsThe CacheStatistics object maintained by this cache.
- 
Constructor SummaryConstructorsConstructorDescriptionSimpleOverflowMap(ObservableMap mapFront, Map mapBack) Construct a SimpleOverflowMap using two specified maps: FrontMap (aka "cache" or "shallow") and BackMap (aka "file" or "deep")SimpleOverflowMap(ObservableMap mapFront, Map mapBack, Map mapMiss) Construct a SimpleOverflowMap using three specified maps: Front Map (aka "cache" or "shallow") and Back Map (aka "file" or "deep") Miss Cache
- 
Method SummaryModifier and TypeMethodDescriptionprotected SimpleOverflowMap.Status[]beginBulkKeyProcess(Object[] aoKey) Begin key-level procecessing for any number of keys.protected SimpleOverflowMap.StatusbeginKeyProcess(Object oKey) Block until a key is available for processing, and return the Status object for that key.protected voidBlock until this thread has exclusive access to perform operations against the OverflowMap.voidclear()Clear all key/value mappings.booleancontainsKey(Object oKey) Returns true if this map contains a mapping for the specified key.protected voidendBulkKeyProcess(Object[] aoKey, SimpleOverflowMap.Status[] aStatus) Finish the processing of any number of keys.protected voidendKeyProcess(Object oKey, SimpleOverflowMap.Status status) Finish the processing of a single key.protected voidRelease exclusive access for the OverflowMap.Returns the value to which this map maps the specified key.Returns the back Map.Returns the CacheStatistics for this cache.protected ListObtain the List of keys that may have deferred events.Returns the front Map.protected MapListenerGet the MapListener for the front map.protected GategetGate()Obtain the Gate for managing key-level and Collection-level operations against the Map, versus Map-level operations themselves.Returns the optional miss cache.protected MapObtain the Map of Status objects for entries managed by this Overflow Map.protected MapListenerFactory pattern: Front Map Listener.protected SimpleOverflowMap.StatusFactory method: Instantiate a Status object.booleanisEmpty()Returns true if this map contains no key-value mappings.booleanDetermine if the front Map is more efficiently updated using putAll.booleanDetermine if null values are permitted.protected IteratorCreate an iterator over the keys in this Map.protected voidonFrontEvent(MapEvent evt) Either handle an event by turning it over to another thread that is processing the key specified by the event, or take responsibility on this thread for deferring the event and registering its immediate side-effects.protected voidProcess deferred events, if there are any.protected voidprocessFrontEvent(SimpleOverflowMap.Status status, MapEvent evt) Process an event.Associates the specified value with the specified key in this map.voidCopies all of the mappings from the specified map to this map.protected static voidHelper to put a value into a map using either the put or putAll method.Removes the mapping for this key from this map if present.protected booleanremoveBlind(Object oKey) Removes the mapping for this key from this map if present.protected voidsetFrontMapListener(MapListener listener) Specify the MapListener for the front map.voidsetFrontPutBlind(boolean fUseFrontPutAll) Specify whether the front Map is more efficiently updated using putAll.voidsetMissCache(Map mapMiss) Set Miss Cache.voidsetNullValuesAllowed(boolean fAllowNulls) Specify whether null values are permitted.intsize()Returns the number of key-value mappings in this map.protected static voidverifyNoNulls(Collection collection, String sAssert) Check the passed collection for nulls, and fail if it contains any.protected static voidwarnEventSequence(MapEvent evtOld, MapEvent evtNew) Issue a one-time warning that events are being received in an order than cannot be explained by normal operation according to the contracts expected by this OverflowMap.Methods inherited from class com.tangosol.util.AbstractKeyBasedMapclone, containsValue, entrySet, equals, getAll, hashCode, instantiateEntrySet, instantiateKeySet, instantiateValues, keySet, toString, valuesMethods inherited from class com.tangosol.util.Baseazzert, azzert, azzert, azzertFailed, breakLines, breakLines, capitalize, checkNotEmpty, checkNotNull, checkRange, computeSafeWaitTime, decimalValue, dup, dup, ensureBigDecimal, ensureClassLoader, ensureRuntimeException, ensureRuntimeException, equals, equalsDeep, err, err, err, err, err, escape, formatDateTime, getCallerStackFrame, getCommonMonitor, getCommonMonitor, getCommonMonitor, getContextClassLoader, getContextClassLoader, getDeepMessage, getErr, getLastSafeTimeMillis, getLog, getMaxDecDigits, getMaxHexDigits, getOriginalException, getOut, getProcessRandom, getRandom, getRandomBinary, getRandomBinary, getRandomString, getSafeTimeMillis, getStackFrame, getStackFrames, getStackTrace, getStackTrace, getStackTrace, getThreadFactory, getTimeZone, getUpTimeMillis, hashCode, hexValue, indentString, indentString, isDecimal, isHex, isLogEcho, isOctal, log, log, log, log, log, makeInteger, makeLong, makeThread, mergeArray, mergeBooleanArray, mergeByteArray, mergeCharArray, mergeDoubleArray, mergeFloatArray, mergeIntArray, mergeLongArray, mod, mod, octalValue, out, out, out, out, out, pad, parseBandwidth, parseBandwidth, parseDelimitedString, parseHex, parseHex, parseMemorySize, parseMemorySize, parsePercentage, parseTime, parseTime, parseTimeNanos, parseTimeNanos, printStackTrace, randomize, randomize, randomize, randomize, read, read, read, read, read, read, read, replace, setErr, setLog, setLogEcho, setOut, sleep, toBandwidthString, toBandwidthString, toCharEscape, toCrc, toCrc, toCrc, toCrc, toCrc, toDecString, toDelimitedString, toDelimitedString, toDelimitedString, toDelimitedString, toHex, toHex, toHexDump, toHexEscape, toHexEscape, toHexEscape, toHexEscape, toHexString, toMemorySizeString, toMemorySizeString, toQuotedCharEscape, toQuotedStringEscape, toSqlString, toString, toString, toStringEscape, toUnicodeEscape, trace, trace, trace, trace, trace, trace, trace, trace, trace, truncateString, truncateString, waitMethods inherited from class java.lang.Objectfinalize, getClass, notify, notifyAll, wait, wait, waitMethods inherited from interface java.util.Mapcompute, computeIfAbsent, computeIfPresent, forEach, getOrDefault, merge, putIfAbsent, remove, replace, replace, replaceAll
- 
Field Details- 
ENTRY_INSERTEDpublic static final int ENTRY_INSERTEDThis event indicates that an entry has been added to the map.- See Also:
 
- 
ENTRY_UPDATEDpublic static final int ENTRY_UPDATEDThis event indicates that an entry has been updated in the map.- See Also:
 
- 
ENTRY_DELETEDpublic static final int ENTRY_DELETEDThis event indicates that an entry has been removed from the map.- See Also:
 
- 
m_mapFrontThe "front" map, which is size-limited.
- 
m_mapBackThe "back" map, which the front overflows to.
- 
m_mapMissThe miss cache; may be null.
- 
m_statsThe CacheStatistics object maintained by this cache.
 
- 
- 
Constructor Details- 
SimpleOverflowMapConstruct a SimpleOverflowMap using two specified maps:- FrontMap (aka "cache" or "shallow") and
- BackMap (aka "file" or "deep")
 - Parameters:
- mapFront- front map
- mapBack- back map
 
- 
SimpleOverflowMapConstruct a SimpleOverflowMap using three specified maps:- Front Map (aka "cache" or "shallow") and
- Back Map (aka "file" or "deep")
- Miss Cache
 - Parameters:
- mapFront- front map
- mapBack- back map
- mapMiss- an optional miss cache
 
 
- 
- 
Method Details- 
clearpublic void clear()Clear all key/value mappings.- Specified by:
- clearin interface- Map
- Overrides:
- clearin class- AbstractKeyBasedMap
 
- 
containsKeyReturns true if this map contains a mapping for the specified key.- Specified by:
- containsKeyin interface- Map
- Overrides:
- containsKeyin class- AbstractKeyBasedMap
- Returns:
- true if this map contains a mapping for the specified key, false otherwise.
 
- 
getReturns the value to which this map maps the specified key.- Specified by:
- getin interface- Map
- Specified by:
- getin class- AbstractKeyBasedMap
- 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
 
- 
isEmptypublic boolean isEmpty()Returns true if this map contains no key-value mappings.- Specified by:
- isEmptyin interface- Map
- Overrides:
- isEmptyin class- AbstractKeyBasedMap
- Returns:
- true if this map contains no key-value mappings
 
- 
putAssociates the specified value with the specified key in this map.- Specified by:
- putin interface- Map
- Overrides:
- putin class- AbstractKeyBasedMap
- 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
 
- 
putAllCopies all of the mappings from the specified map to this map. The effect of this call is equivalent to that of callingput(java.lang.Object, java.lang.Object)on this map once for each mapping in the passed map. The behavior of this operation is unspecified if the passed map is modified while the operation is in progress.- Specified by:
- putAllin interface- Map
- Overrides:
- putAllin class- AbstractKeyBasedMap
- Parameters:
- map- the Map containing the key/value pairings to put into this Map
 
- 
removeRemoves 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- AbstractKeyBasedMap
- 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.
 
- 
sizepublic int size()Returns the number of key-value mappings in this map.- Specified by:
- sizein interface- Map
- Overrides:
- sizein class- AbstractKeyBasedMap
- Returns:
- the number of key-value mappings in this map
 
- 
iterateKeysCreate an iterator over the keys in this Map.- Specified by:
- iterateKeysin class- AbstractKeyBasedMap
- Returns:
- a new instance of an Iterator over the keys in this Map
 
- 
removeBlindRemoves the mapping for this key from this map if present. This method exists to allow sub-classes to optmiize remove functionalitly for situations in which the original value is not required.- Overrides:
- removeBlindin class- AbstractKeyBasedMap
- Parameters:
- oKey- key whose mapping is to be removed from the map
- Returns:
- true iff the Map changed as the result of this operation
 
- 
getFrontMapReturns the front Map.Warning: Direct modifications of the returned map may cause unpredictable behavior of the Overflow Map. - Returns:
- the front Map
 
- 
getBackMapReturns the back Map.Warning: Direct modifications of the returned map may cause unpredictable behavior of the Overflow Map. - Returns:
- the back Map
 
- 
getMissCacheReturns the optional miss cache.Warning: Direct modifications of the returned map may cause unpredictable behavior of the Overflow Map. - Returns:
- the miss cache, or null if there is no miss cache
 
- 
setMissCacheSet Miss Cache. Note: do not use other than in OverflowScheme#realizeMap(...)- Parameters:
- mapMiss- miss cache.
 
- 
getCacheStatisticsReturns the CacheStatistics for this cache.- Returns:
- a CacheStatistics object
 
- 
getGateObtain the Gate for managing key-level and Collection-level operations against the Map, versus Map-level operations themselves.- Returns:
- the Gate for the OverflowMap
 
- 
getStatusMapObtain the Map of Status objects for entries managed by this Overflow Map. There will be a Status object for each entry in the front map, and a Status object for each key that has a current operation underway.- Returns:
- the Map of Status objects
 
- 
getDeferredListObtain the List of keys that may have deferred events.- Returns:
- the List of keys of deferred-event Status objects
 
- 
isNullValuesAllowedpublic boolean isNullValuesAllowed()Determine if null values are permitted. By default, they are not.- Returns:
- true iff null values are permitted
 
- 
setNullValuesAllowedpublic void setNullValuesAllowed(boolean fAllowNulls) Specify whether null values are permitted.- Parameters:
- fAllowNulls- pass true to allow null values; false to disallow
 
- 
isFrontPutBlindpublic boolean isFrontPutBlind()Determine if the front Map is more efficiently updated using putAll. (The use of putAll instead of put is called put-blind because it does not return a value.)- Returns:
- true iff the use of the put method should be avoided when updating the front Map, and putAll should be used instead
 
- 
setFrontPutBlindpublic void setFrontPutBlind(boolean fUseFrontPutAll) Specify whether the front Map is more efficiently updated using putAll.- Parameters:
- fUseFrontPutAll- pass true to allow null values; false to disallow
 
- 
getFrontMapListenerGet the MapListener for the front map.- Returns:
- the MapListener for the front map
 
- 
setFrontMapListenerSpecify the MapListener for the front map.The caller is required to manage all of the thread concurrency issues associated with modifying the listener. - Parameters:
- listener- the MapListener for the front map
 
- 
instantiateFrontMapListenerFactory pattern: Front Map Listener.- Returns:
- a new instance of the listener for the front map
 
- 
onFrontEventEither handle an event by turning it over to another thread that is processing the key specified by the event, or take responsibility on this thread for deferring the event and registering its immediate side-effects.- Parameters:
- evt- the event
 
- 
processFrontEventProcess an event. The Status must already be owned by this thread and in the processing or committing state.- Parameters:
- status- the status
- evt- the event to process; may be null
 
- 
beginKeyProcessBlock until a key is available for processing, and return the Status object for that key. The caller is then expected to perform its processing, during which time events against the Map Entry may occur. Note that those events can occur on threads other than the current thread; when this current thread can no longer handle events from other threads, it must callSimpleOverflowMap.Status.closeProcessing()and then perform its final adjustments to the Status data structure, handling any events that were queued in the meantime on the Status. After completing the processing during this "quiet period" in which all other threads are prevented from accessing this entry or handling events for this entry, then the caller must callendKeyProcess(java.lang.Object, com.tangosol.net.cache.SimpleOverflowMap.Status)passing the Status object returned from this method.- Parameters:
- oKey- the key to process
- Returns:
- the Status object for the specified key
 
- 
endKeyProcessFinish the processing of a single key.- Parameters:
- oKey- the key
- status- the Status object returned from the call to- beginKeyProcess(java.lang.Object)
 
- 
beginBulkKeyProcessBegin key-level procecessing for any number of keys.- Parameters:
- aoKey- an array of zero or more keys; note that this array may be re-ordered by this method
- Returns:
- an array of Status objects corresponding to the passed keys
- See Also:
 
- 
endBulkKeyProcessFinish the processing of any number of keys.- Parameters:
- aoKey- the same array of keys as were passed to- beginBulkKeyProcess(java.lang.Object[])
- aStatus- the array of Status objects returned from the call to- beginBulkKeyProcess(java.lang.Object[])
 
- 
beginMapProcessprotected void beginMapProcess()Block until this thread has exclusive access to perform operations against the OverflowMap.
- 
endMapProcessprotected void endMapProcess()Release exclusive access for the OverflowMap.
- 
processDeferredEventsprotected void processDeferredEvents()Process deferred events, if there are any. This implementation processes only the first deferred event that it encounters.
- 
verifyNoNullsCheck the passed collection for nulls, and fail if it contains any.- Parameters:
- collection- a Collection
- sAssert- the human-readable description of the error if any nulls are found in the passed Collection
 
- 
putOneHelper to put a value into a map using either the put or putAll method.- Parameters:
- map- the Map to put into
- oKey- the key to put
- oValue- the value to put
- fPutBlind- true to use the putBlind optimization
 
- 
warnEventSequenceIssue a one-time warning that events are being received in an order than cannot be explained by normal operation according to the contracts expected by this OverflowMap.- Parameters:
- evtOld- the previous (potentially amalgamated) event
- evtNew- the new event
 
- 
instantiateStatusFactory method: Instantiate a Status object.- Returns:
- a new Status object
 
 
-