Package org.onosproject.store.primitives
Class DefaultConsistentTreeMap<V>
- java.lang.Object
- 
- org.onosproject.store.service.Synchronous<AsyncConsistentTreeMap<V>>
- 
- org.onosproject.store.primitives.DefaultConsistentTreeMap<V>
 
 
- 
- All Implemented Interfaces:
- Iterable<Map.Entry<String,Versioned<V>>>,- ConsistentMap<String,V>,- ConsistentTreeMap<V>,- DistributedPrimitive
 
 public class DefaultConsistentTreeMap<V> extends Synchronous<AsyncConsistentTreeMap<V>> implements ConsistentTreeMap<V> Implementation of theConsistentTreeMapinterface.
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface org.onosproject.store.service.DistributedPrimitiveDistributedPrimitive.Status, DistributedPrimitive.Type
 
- 
 - 
Field Summary- 
Fields inherited from interface org.onosproject.store.service.DistributedPrimitiveDEFAULT_OPERATION_TIMEOUT_MILLIS
 
- 
 - 
Constructor SummaryConstructors Constructor Description DefaultConsistentTreeMap(AsyncConsistentTreeMap<V> treeMap, long operationTimeoutMillis)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddListener(MapEventListener<String,V> listener, Executor executor)Registers the specified listener to be notified whenever the map is updated.Map<String,V>asJavaMap()Returns a java.util.Map instance backed by this ConsistentMap.Map.Entry<String,Versioned<V>>ceilingEntry(String key)Returns the entry associated with the least key greater than or equal to the key.StringceilingKey(String key)Returns the lowest key greater than or equal to key.voidclear()Removes all of the mappings from this map (optional operation).Versioned<V>compute(String key, BiFunction<? super String,? super V,? extends V> remappingFunction)Attempts to compute a mapping for the specified key and its current mapped value (or null if there is no current mapping).Versioned<V>computeIf(String key, Predicate<? super V> condition, BiFunction<? super String,? super V,? extends V> remappingFunction)If the value for the specified key satisfies a condition, attempts to compute a new mapping given the key and its current mapped value.Versioned<V>computeIfAbsent(String key, Function<? super String,? extends V> mappingFunction)If the specified key is not already associated with a value (or is mapped to null), attempts to compute its value using the given mapping function and enters it into this map unless null.Versioned<V>computeIfPresent(String key, BiFunction<? super String,? super V,? extends V> remappingFunction)If the value for the specified key is present and non-null, attempts to compute a new mapping given the key and its current mapped value.booleancontainsKey(String key)Returns true if this map contains a mapping for the specified key.booleancontainsValue(V value)Returns true if this map contains the specified value.Set<Map.Entry<String,Versioned<V>>>entrySet()Returns the set of entries contained in this map.Map.Entry<String,Versioned<V>>firstEntry()Returns the entry associated with the lowest key in the map.StringfirstKey()Returns the lowest key in the map.Map.Entry<String,Versioned<V>>floorEntry(String key)Returns the entry associated with the greatest key less than or equal to key.StringfloorKey(String key)Returns the entry associated with the highest key less than or equal to key.Versioned<V>get(String key)Returns the value (and version) to which the specified key is mapped, or null if this map contains no mapping for the key.Versioned<V>getOrDefault(String key, V defaultValue)Returns the value (and version) to which the specified key is mapped, or the provided default value if this map contains no mapping for the key.Map.Entry<String,Versioned<V>>higherEntry(String key)Returns the entry associated with the lest key greater than key.StringhigherKey(String key)Returns the lowest key greater than key.booleanisEmpty()Returns true if the map is empty.Iterator<Map.Entry<String,Versioned<V>>>iterator()Set<String>keySet()Returns a Set view of the keys contained in this map.Map.Entry<String,Versioned<V>>lastEntry()Returns the entry associated with the highest key in the map.StringlastKey()Returns the highest key in the map.Map.Entry<String,Versioned<V>>lowerEntry(String key)Returns the entry associated with the largest key less than key.StringlowerKey(String key)Returns the entry associated with the greatest key less than key.NavigableSet<String>navigableKeySet()Returns a navigable set of the keys in this map.Map.Entry<String,Versioned<V>>pollFirstEntry()Returns and removes the entry associated with the lowest key.Map.Entry<String,Versioned<V>>pollLastEntry()Returns and removes the entry associated with the highest key.Versioned<V>put(String key, V value)Associates the specified value with the specified key in this map (optional operation).Versioned<V>putAndGet(String key, V value)Associates the specified value with the specified key in this map (optional operation).Versioned<V>putIfAbsent(String key, V value)If the specified key is not already associated with a value associates it with the given value and returns null, else returns the current value.Versioned<V>remove(String key)Removes the mapping for a key from this map if it is present (optional operation).booleanremove(String key, long version)Removes the entry for the specified key only if its current version in the map is equal to the specified version.booleanremove(String key, V value)Removes the entry for the specified key only if it is currently mapped to the specified value.voidremoveListener(MapEventListener<String,V> listener)Unregisters the specified listener such that it will no longer receive map change notifications.booleanreplace(String key, long oldVersion, V newValue)Replaces the entry for the specified key only if it is currently mapped to the specified version.Versioned<V>replace(String key, V value)Replaces the entry for the specified key only if there is any value which associated with specified key.booleanreplace(String key, V oldValue, V newValue)Replaces the entry for the specified key only if currently mapped to the specified value.intsize()Returns the number of entries in the map.NavigableMap<String,V>subMap(String upperKey, String lowerKey, boolean inclusiveUpper, boolean inclusiveLower)Returns a navigable map containing the entries from the original map which are larger than (or if specified equal to)lowerKeyAND less than (or if specified equal to)upperKey.Collection<Versioned<V>>values()Returns the collection of values (and associated versions) contained in this map.- 
Methods inherited from class org.onosproject.store.service.Synchronousdestroy, name, primitiveType
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface org.onosproject.store.service.ConsistentMapaddListener, stream
 - 
Methods inherited from interface org.onosproject.store.service.DistributedPrimitiveaddStatusChangeListener, applicationId, destroy, name, primitiveType, removeStatusChangeListener, statusChangeListeners
 - 
Methods inherited from interface java.lang.IterableforEach, spliterator
 
- 
 
- 
- 
- 
Constructor Detail- 
DefaultConsistentTreeMappublic DefaultConsistentTreeMap(AsyncConsistentTreeMap<V> treeMap, long operationTimeoutMillis) 
 
- 
 - 
Method Detail- 
firstKeypublic String firstKey() Description copied from interface:ConsistentTreeMapReturns the lowest key in the map.- Specified by:
- firstKeyin interface- ConsistentTreeMap<V>
- Returns:
- the key or null if none exist
 
 - 
lastKeypublic String lastKey() Description copied from interface:ConsistentTreeMapReturns the highest key in the map.- Specified by:
- lastKeyin interface- ConsistentTreeMap<V>
- Returns:
- the key or null if none exist
 
 - 
ceilingEntrypublic Map.Entry<String,Versioned<V>> ceilingEntry(String key) Description copied from interface:ConsistentTreeMapReturns the entry associated with the least key greater than or equal to the key.- Specified by:
- ceilingEntryin interface- ConsistentTreeMap<V>
- Parameters:
- key- the key
- Returns:
- the entry or null
 
 - 
floorEntrypublic Map.Entry<String,Versioned<V>> floorEntry(String key) Description copied from interface:ConsistentTreeMapReturns the entry associated with the greatest key less than or equal to key.- Specified by:
- floorEntryin interface- ConsistentTreeMap<V>
- Parameters:
- key- the key
- Returns:
- the entry or null
 
 - 
higherEntrypublic Map.Entry<String,Versioned<V>> higherEntry(String key) Description copied from interface:ConsistentTreeMapReturns the entry associated with the lest key greater than key.- Specified by:
- higherEntryin interface- ConsistentTreeMap<V>
- Parameters:
- key- the key
- Returns:
- the entry or null
 
 - 
lowerEntrypublic Map.Entry<String,Versioned<V>> lowerEntry(String key) Description copied from interface:ConsistentTreeMapReturns the entry associated with the largest key less than key.- Specified by:
- lowerEntryin interface- ConsistentTreeMap<V>
- Parameters:
- key- the key
- Returns:
- the entry or null
 
 - 
firstEntrypublic Map.Entry<String,Versioned<V>> firstEntry() Description copied from interface:ConsistentTreeMapReturns the entry associated with the lowest key in the map.- Specified by:
- firstEntryin interface- ConsistentTreeMap<V>
- Returns:
- the entry or null
 
 - 
lastEntrypublic Map.Entry<String,Versioned<V>> lastEntry() Description copied from interface:ConsistentTreeMapReturns the entry associated with the highest key in the map.- Specified by:
- lastEntryin interface- ConsistentTreeMap<V>
- Returns:
- the entry or null
 
 - 
pollFirstEntrypublic Map.Entry<String,Versioned<V>> pollFirstEntry() Description copied from interface:ConsistentTreeMapReturns and removes the entry associated with the lowest key.- Specified by:
- pollFirstEntryin interface- ConsistentTreeMap<V>
- Returns:
- the entry or null
 
 - 
pollLastEntrypublic Map.Entry<String,Versioned<V>> pollLastEntry() Description copied from interface:ConsistentTreeMapReturns and removes the entry associated with the highest key.- Specified by:
- pollLastEntryin interface- ConsistentTreeMap<V>
- Returns:
- the entry or null
 
 - 
lowerKeypublic String lowerKey(String key) Description copied from interface:ConsistentTreeMapReturns the entry associated with the greatest key less than key.- Specified by:
- lowerKeyin interface- ConsistentTreeMap<V>
- Parameters:
- key- the key
- Returns:
- the entry or null
 
 - 
floorKeypublic String floorKey(String key) Description copied from interface:ConsistentTreeMapReturns the entry associated with the highest key less than or equal to key.- Specified by:
- floorKeyin interface- ConsistentTreeMap<V>
- Parameters:
- key- the key
- Returns:
- the entry or null
 
 - 
ceilingKeypublic String ceilingKey(String key) Description copied from interface:ConsistentTreeMapReturns the lowest key greater than or equal to key.- Specified by:
- ceilingKeyin interface- ConsistentTreeMap<V>
- Parameters:
- key- the key
- Returns:
- the key or null
 
 - 
higherKeypublic String higherKey(String key) Description copied from interface:ConsistentTreeMapReturns the lowest key greater than key.- Specified by:
- higherKeyin interface- ConsistentTreeMap<V>
- Parameters:
- key- the key
- Returns:
- the key or null
 
 - 
navigableKeySetpublic NavigableSet<String> navigableKeySet() Description copied from interface:ConsistentTreeMapReturns a navigable set of the keys in this map.- Specified by:
- navigableKeySetin interface- ConsistentTreeMap<V>
- Returns:
- a navigable key set
 
 - 
sizepublic int size() Description copied from interface:ConsistentMapReturns the number of entries in the map.- Specified by:
- sizein interface- ConsistentMap<String,V>
- Returns:
- map size.
 
 - 
isEmptypublic boolean isEmpty() Description copied from interface:ConsistentMapReturns true if the map is empty.- Specified by:
- isEmptyin interface- ConsistentMap<String,V>
- Returns:
- true if map has no entries, false otherwise
 
 - 
containsKeypublic boolean containsKey(String key) Description copied from interface:ConsistentMapReturns true if this map contains a mapping for the specified key.- Specified by:
- containsKeyin interface- ConsistentMap<String,V>
- Parameters:
- key- key
- Returns:
- true if map contains key, false otherwise
 
 - 
containsValuepublic boolean containsValue(V value) Description copied from interface:ConsistentMapReturns true if this map contains the specified value.- Specified by:
- containsValuein interface- ConsistentMap<String,V>
- Parameters:
- value- value
- Returns:
- true if map contains value, false otherwise.
 
 - 
getpublic Versioned<V> get(String key) Description copied from interface:ConsistentMapReturns the value (and version) to which the specified key is mapped, or null if this map contains no mapping for the key.- Specified by:
- getin interface- ConsistentMap<String,V>
- Parameters:
- key- the key whose associated value (and version) is to be returned
- Returns:
- the value (and version) to which the specified key is mapped, or null if this map contains no mapping for the key
 
 - 
getOrDefaultpublic Versioned<V> getOrDefault(String key, V defaultValue) Description copied from interface:ConsistentMapReturns the value (and version) to which the specified key is mapped, or the provided default value if this map contains no mapping for the key.Note: a non-null Versionedvalue will be returned even if thedefaultValueisnull.- Specified by:
- getOrDefaultin interface- ConsistentMap<String,V>
- Parameters:
- key- the key whose associated value (and version) is to be returned
- defaultValue- the default value to return if the key is not set
- Returns:
- the value (and version) to which the specified key is mapped, or null if this map contains no mapping for the key
 
 - 
computeIfAbsentpublic Versioned<V> computeIfAbsent(String key, Function<? super String,? extends V> mappingFunction) Description copied from interface:ConsistentMapIf the specified key is not already associated with a value (or is mapped to null), attempts to compute its value using the given mapping function and enters it into this map unless null.- Specified by:
- computeIfAbsentin interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is to be associated
- mappingFunction- the function to compute a value
- Returns:
- the current (existing or computed) value associated with the specified key,
 or null if the computed value is null. Method throws ConsistentMapException.ConcurrentModificationif a concurrent modification of map is detected
 
 - 
computepublic Versioned<V> compute(String key, BiFunction<? super String,? super V,? extends V> remappingFunction) Description copied from interface:ConsistentMapAttempts to compute a mapping for the specified key and its current mapped value (or null if there is no current mapping). If the computed value is null, the current mapping will be removed from the map.- Specified by:
- computein interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is to be associated
- remappingFunction- the function to compute a value
- Returns:
- the new value associated with the specified key, or null if none.
 This method throws ConsistentMapException.ConcurrentModificationif a concurrent modification of map is detected
 
 - 
computeIfPresentpublic Versioned<V> computeIfPresent(String key, BiFunction<? super String,? super V,? extends V> remappingFunction) Description copied from interface:ConsistentMapIf the value for the specified key is present and non-null, attempts to compute a new mapping given the key and its current mapped value. If the computed value is null, the current mapping will be removed from the map.- Specified by:
- computeIfPresentin interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is to be associated
- remappingFunction- the function to compute a value
- Returns:
- the new value associated with the specified key, or null if none.
 This method throws ConsistentMapException.ConcurrentModificationif a concurrent modification of map is detected
 
 - 
computeIfpublic Versioned<V> computeIf(String key, Predicate<? super V> condition, BiFunction<? super String,? super V,? extends V> remappingFunction) Description copied from interface:ConsistentMapIf the value for the specified key satisfies a condition, attempts to compute a new mapping given the key and its current mapped value. If the computed value is null, the current mapping will be removed from the map.- Specified by:
- computeIfin interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is to be associated
- condition- condition that should evaluate to true for the computation to proceed
- remappingFunction- the function to compute a value
- Returns:
- the new value associated with the specified key, or the old value if condition evaluates to false.
 This method throws ConsistentMapException.ConcurrentModificationif a concurrent modification of map is detected
 
 - 
putpublic Versioned<V> put(String key, V value) Description copied from interface:ConsistentMapAssociates the specified value with the specified key in this map (optional operation). If the map previously contained a mapping for the key, the old value is replaced by the specified value.- Specified by:
- putin interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is to be associated
- value- value to be associated with the specified key
- Returns:
- the previous value (and version) associated with key, or null if there was no mapping for key.
 
 - 
putAndGetpublic Versioned<V> putAndGet(String key, V value) Description copied from interface:ConsistentMapAssociates the specified value with the specified key in this map (optional operation). If the map previously contained a mapping for the key, the old value is replaced by the specified value.- Specified by:
- putAndGetin interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is to be associated
- value- value to be associated with the specified key
- Returns:
- new value.
 
 - 
removepublic Versioned<V> remove(String key) Description copied from interface:ConsistentMapRemoves the mapping for a key from this map if it is present (optional operation).- Specified by:
- removein interface- ConsistentMap<String,V>
- Parameters:
- key- key whose value is to be removed from the map
- Returns:
- the value (and version) to which this map previously associated the key, or null if the map contained no mapping for the key.
 
 - 
clearpublic void clear() Description copied from interface:ConsistentMapRemoves all of the mappings from this map (optional operation). The map will be empty after this call returns.- Specified by:
- clearin interface- ConsistentMap<String,V>
 
 - 
keySetpublic Set<String> keySet() Description copied from interface:ConsistentMapReturns a Set view of the keys contained in this map. This method differs from the behavior of java.util.Map.keySet() in that what is returned is a unmodifiable snapshot view of the keys in the ConsistentMap. Attempts to modify the returned set, whether direct or via its iterator, result in an UnsupportedOperationException.- Specified by:
- keySetin interface- ConsistentMap<String,V>
- Returns:
- a set of the keys contained in this map
 
 - 
valuespublic Collection<Versioned<V>> values() Description copied from interface:ConsistentMapReturns the collection of values (and associated versions) contained in this map. This method differs from the behavior of java.util.Map.values() in that what is returned is a unmodifiable snapshot view of the values in the ConsistentMap. Attempts to modify the returned collection, whether direct or via its iterator, result in an UnsupportedOperationException.- Specified by:
- valuesin interface- ConsistentMap<String,V>
- Returns:
- a collection of the values (and associated versions) contained in this map
 
 - 
entrySetpublic Set<Map.Entry<String,Versioned<V>>> entrySet() Description copied from interface:ConsistentMapReturns the set of entries contained in this map. This method differs from the behavior of java.util.Map.entrySet() in that what is returned is a unmodifiable snapshot view of the entries in the ConsistentMap. Attempts to modify the returned set, whether direct or via its iterator, result in an UnsupportedOperationException.- Specified by:
- entrySetin interface- ConsistentMap<String,V>
- Returns:
- set of entries contained in this map.
 
 - 
putIfAbsentpublic Versioned<V> putIfAbsent(String key, V value) Description copied from interface:ConsistentMapIf the specified key is not already associated with a value associates it with the given value and returns null, else returns the current value.- Specified by:
- putIfAbsentin interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is to be associated
- value- value to be associated with the specified key
- Returns:
- the previous value associated with the specified key or null if key does not already mapped to a value.
 
 - 
removepublic boolean remove(String key, V value) Description copied from interface:ConsistentMapRemoves the entry for the specified key only if it is currently mapped to the specified value.- Specified by:
- removein interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is associated
- value- value expected to be associated with the specified key
- Returns:
- true if the value was removed
 
 - 
removepublic boolean remove(String key, long version) Description copied from interface:ConsistentMapRemoves the entry for the specified key only if its current version in the map is equal to the specified version.- Specified by:
- removein interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified version is associated
- version- version expected to be associated with the specified key
- Returns:
- true if the value was removed
 
 - 
replacepublic Versioned<V> replace(String key, V value) Description copied from interface:ConsistentMapReplaces the entry for the specified key only if there is any value which associated with specified key.- Specified by:
- replacein interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is associated
- value- value expected to be associated with the specified key
- Returns:
- the previous value associated with the specified key or null
 
 - 
replacepublic boolean replace(String key, V oldValue, V newValue) Description copied from interface:ConsistentMapReplaces the entry for the specified key only if currently mapped to the specified value.- Specified by:
- replacein interface- ConsistentMap<String,V>
- Parameters:
- key- key with which the specified value is associated
- oldValue- value expected to be associated with the specified key
- newValue- value to be associated with the specified key
- Returns:
- true if the value was replaced
 
 - 
replacepublic boolean replace(String key, long oldVersion, V newValue) Description copied from interface:ConsistentMapReplaces the entry for the specified key only if it is currently mapped to the specified version.- Specified by:
- replacein interface- ConsistentMap<String,V>
- Parameters:
- key- key key with which the specified value is associated
- oldVersion- version expected to be associated with the specified key
- newValue- value to be associated with the specified key
- Returns:
- true if the value was replaced
 
 - 
addListenerpublic void addListener(MapEventListener<String,V> listener, Executor executor) Description copied from interface:ConsistentMapRegisters the specified listener to be notified whenever the map is updated.- Specified by:
- addListenerin interface- ConsistentMap<String,V>
- Parameters:
- listener- listener to notify about map events
- executor- executor to use for handling incoming map events
 
 - 
removeListenerpublic void removeListener(MapEventListener<String,V> listener) Description copied from interface:ConsistentMapUnregisters the specified listener such that it will no longer receive map change notifications.- Specified by:
- removeListenerin interface- ConsistentMap<String,V>
- Parameters:
- listener- listener to unregister
 
 - 
asJavaMappublic Map<String,V> asJavaMap() Description copied from interface:ConsistentMapReturns a java.util.Map instance backed by this ConsistentMap.- Specified by:
- asJavaMapin interface- ConsistentMap<String,V>
- Returns:
- java.util.Map
 
 - 
subMappublic NavigableMap<String,V> subMap(String upperKey, String lowerKey, boolean inclusiveUpper, boolean inclusiveLower) Description copied from interface:ConsistentTreeMapReturns a navigable map containing the entries from the original map which are larger than (or if specified equal to)lowerKeyAND less than (or if specified equal to)upperKey.- Specified by:
- subMapin interface- ConsistentTreeMap<V>
- Parameters:
- upperKey- the upper bound for the keys in this map
- lowerKey- the lower bound for the keys in this map
- inclusiveUpper- whether keys equal to the upperKey should be included
- inclusiveLower- whether keys equal to the lowerKey should be included
- Returns:
- a navigable map containing entries in the specified range (this may be empty)
 
 
- 
 
-