Class ForwardingNavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- java.lang.Object
- 
- com.google.common.collect.ForwardingObject
- 
- com.google.common.collect.ForwardingMap<K,V>
- 
- com.google.common.collect.ForwardingSortedMap<K,V>
- 
- com.google.common.collect.ForwardingNavigableMap<K,V>
 
 
 
 
- 
- All Implemented Interfaces:
- Map<K,V>,- NavigableMap<K,V>,- SortedMap<K,V>
 
 @GwtIncompatible public abstract class ForwardingNavigableMap<K extends @Nullable Object,V extends @Nullable Object> extends ForwardingSortedMap<K,V> implements NavigableMap<K,V> A navigable map which forwards all its method calls to another navigable map. Subclasses should override one or more methods to modify the behavior of the backing map as desired per the decorator pattern.Warning: The methods of ForwardingNavigableMapforward indiscriminately to the methods of the delegate. For example, overridingForwardingMap.put(K, V)alone will not change the behavior ofForwardingMap.putAll(java.util.Map<? extends K, ? extends V>), which can lead to unexpected behavior. In this case, you should overrideputAllas well, either providing your own implementation, or delegating to the providedstandardPutAllmethod.defaultmethod warning: This class does not forward calls todefaultmethods. Instead, it inherits their default implementations. When those implementations invoke methods, they invoke methods on theForwardingNavigableMap.Each of the standardmethods uses the map's comparator (or the natural ordering of the elements, if there is no comparator) to test element equality. As a result, if the comparator is not consistent with equals, some of the standard implementations may violate theMapcontract.The standardmethods and the collection views they return are not guaranteed to be thread-safe, even when all of the methods that they depend on are thread-safe.- Since:
- 12.0
- Author:
- Louis Wasserman
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected classForwardingNavigableMap.StandardDescendingMapA sensible implementation ofNavigableMap.descendingMap()in terms of the methods of thisNavigableMap.protected classForwardingNavigableMap.StandardNavigableKeySetA sensible implementation ofNavigableMap.navigableKeySet()in terms of the methods of thisNavigableMap.- 
Nested classes/interfaces inherited from class com.google.common.collect.ForwardingSortedMapForwardingSortedMap.StandardKeySet
 - 
Nested classes/interfaces inherited from class com.google.common.collect.ForwardingMapForwardingMap.StandardEntrySet, ForwardingMap.StandardValues
 
- 
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedForwardingNavigableMap()Constructor for use by subclasses.
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description Map.Entry<K,V>ceilingEntry(K key)Returns a key-value mapping associated with the least key greater than or equal to the given key, ornullif there is no such key.KceilingKey(K key)Returns the least key greater than or equal to the given key, ornullif there is no such key.protected abstract NavigableMap<K,V>delegate()Returns the backing delegate instance that methods are forwarded to.NavigableSet<K>descendingKeySet()Returns a reverse orderNavigableSetview of the keys contained in this map.NavigableMap<K,V>descendingMap()Returns a reverse order view of the mappings contained in this map.Map.Entry<K,V>firstEntry()Returns a key-value mapping associated with the least key in this map, ornullif the map is empty.Map.Entry<K,V>floorEntry(K key)Returns a key-value mapping associated with the greatest key less than or equal to the given key, ornullif there is no such key.KfloorKey(K key)Returns the greatest key less than or equal to the given key, ornullif there is no such key.NavigableMap<K,V>headMap(K toKey, boolean inclusive)Returns a view of the portion of this map whose keys are less than (or equal to, ifinclusiveis true)toKey.Map.Entry<K,V>higherEntry(K key)Returns a key-value mapping associated with the least key strictly greater than the given key, ornullif there is no such key.KhigherKey(K key)Returns the least key strictly greater than the given key, ornullif there is no such key.Map.Entry<K,V>lastEntry()Returns a key-value mapping associated with the greatest key in this map, ornullif the map is empty.Map.Entry<K,V>lowerEntry(K key)Returns a key-value mapping associated with the greatest key strictly less than the given key, ornullif there is no such key.KlowerKey(K key)Returns the greatest key strictly less than the given key, ornullif there is no such key.NavigableSet<K>navigableKeySet()Returns aNavigableSetview of the keys contained in this map.Map.Entry<K,V>pollFirstEntry()Removes and returns a key-value mapping associated with the least key in this map, ornullif the map is empty.Map.Entry<K,V>pollLastEntry()Removes and returns a key-value mapping associated with the greatest key in this map, ornullif the map is empty.protected Map.Entry<K,V>standardCeilingEntry(K key)protected KstandardCeilingKey(K key)A sensible definition ofceilingKey(K)in terms ofceilingEntry.protected NavigableSet<K>standardDescendingKeySet()protected Map.Entry<K,V>standardFirstEntry()protected KstandardFirstKey()A sensible definition ofForwardingSortedMap.firstKey()in terms offirstEntry.protected Map.Entry<K,V>standardFloorEntry(K key)protected KstandardFloorKey(K key)A sensible definition offloorKey(K)in terms offloorEntry.protected SortedMap<K,V>standardHeadMap(K toKey)A sensible definition ofForwardingSortedMap.headMap(Object)in terms ofheadMap(Object, boolean).protected Map.Entry<K,V>standardHigherEntry(K key)protected KstandardHigherKey(K key)A sensible definition ofhigherKey(K)in terms ofhigherEntry.protected Map.Entry<K,V>standardLastEntry()A sensible definition oflastEntry()in terms of theiterator()of theForwardingMap.entrySet()ofdescendingMap().protected KstandardLastKey()A sensible definition ofForwardingSortedMap.lastKey()in terms oflastEntry.protected Map.Entry<K,V>standardLowerEntry(K key)protected KstandardLowerKey(K key)A sensible definition oflowerKey(K)in terms oflowerEntry.protected Map.Entry<K,V>standardPollFirstEntry()protected Map.Entry<K,V>standardPollLastEntry()A sensible definition ofpollFirstEntry()in terms of theiteratorof theentrySetofdescendingMap.protected SortedMap<K,V>standardSubMap(K fromKey, K toKey)A sensible definition ofForwardingSortedMap.subMap(Object, Object)in terms ofsubMap(Object, boolean, Object, boolean).protected SortedMap<K,V>standardTailMap(K fromKey)A sensible definition ofForwardingSortedMap.tailMap(Object)in terms oftailMap(Object, boolean).NavigableMap<K,V>subMap(K fromKey, boolean fromInclusive, K toKey, boolean toInclusive)Returns a view of the portion of this map whose keys range fromfromKeytotoKey.NavigableMap<K,V>tailMap(K fromKey, boolean inclusive)Returns a view of the portion of this map whose keys are greater than (or equal to, ifinclusiveis true)fromKey.- 
Methods inherited from class com.google.common.collect.ForwardingSortedMapcomparator, firstKey, headMap, lastKey, standardContainsKey, subMap, tailMap
 - 
Methods inherited from class com.google.common.collect.ForwardingMapclear, containsKey, containsValue, entrySet, equals, get, hashCode, isEmpty, keySet, put, putAll, remove, size, standardClear, standardContainsValue, standardEquals, standardHashCode, standardIsEmpty, standardPutAll, standardRemove, standardToString, values
 - 
Methods inherited from class com.google.common.collect.ForwardingObjecttoString
 - 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface java.util.Mapclear, compute, computeIfAbsent, computeIfPresent, containsKey, containsValue, equals, forEach, get, getOrDefault, hashCode, isEmpty, merge, put, putAll, putIfAbsent, remove, remove, replace, replace, replaceAll, size
 - 
Methods inherited from interface java.util.NavigableMapheadMap, subMap, tailMap
 
- 
 
- 
- 
- 
Constructor Detail- 
ForwardingNavigableMapprotected ForwardingNavigableMap() Constructor for use by subclasses.
 
- 
 - 
Method Detail- 
delegateprotected abstract NavigableMap<K,V> delegate() Description copied from class:ForwardingObjectReturns the backing delegate instance that methods are forwarded to. Abstract subclasses generally override this method with an abstract method that has a more specific return type, such asForwardingSet.delegate(). Concrete subclasses override this method to supply the instance being decorated.
 - 
lowerEntry@CheckForNull public Map.Entry<K,V> lowerEntry(K key) Description copied from interface:java.util.NavigableMapReturns a key-value mapping associated with the greatest key strictly less than the given key, ornullif there is no such key.- Specified by:
- lowerEntryin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Parameters:
- key- the key
- Returns:
- an entry with the greatest key less than key, ornullif there is no such key
 
 - 
standardLowerEntry@CheckForNull protected Map.Entry<K,V> standardLowerEntry(K key) A sensible definition oflowerEntry(K)in terms of thelastEntry()ofheadMap(Object, boolean). If you overrideheadMap, you may wish to overridelowerEntryto forward to this implementation.
 - 
lowerKey@CheckForNull public K lowerKey(K key) Description copied from interface:java.util.NavigableMapReturns the greatest key strictly less than the given key, ornullif there is no such key.
 - 
standardLowerKey@CheckForNull protected K standardLowerKey(K key) A sensible definition oflowerKey(K)in terms oflowerEntry. If you overridelowerEntry(K), you may wish to overridelowerKeyto forward to this implementation.
 - 
floorEntry@CheckForNull public Map.Entry<K,V> floorEntry(K key) Description copied from interface:java.util.NavigableMapReturns a key-value mapping associated with the greatest key less than or equal to the given key, ornullif there is no such key.- Specified by:
- floorEntryin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Parameters:
- key- the key
- Returns:
- an entry with the greatest key less than or equal to
         key, ornullif there is no such key
 
 - 
standardFloorEntry@CheckForNull protected Map.Entry<K,V> standardFloorEntry(K key) A sensible definition offloorEntry(K)in terms of thelastEntry()ofheadMap(Object, boolean). If you overrideheadMap, you may wish to overridefloorEntryto forward to this implementation.
 - 
floorKey@CheckForNull public K floorKey(K key) Description copied from interface:java.util.NavigableMapReturns the greatest key less than or equal to the given key, ornullif there is no such key.
 - 
standardFloorKey@CheckForNull protected K standardFloorKey(K key) A sensible definition offloorKey(K)in terms offloorEntry. If you overridefloorEntry, you may wish to overridefloorKeyto forward to this implementation.
 - 
ceilingEntry@CheckForNull public Map.Entry<K,V> ceilingEntry(K key) Description copied from interface:java.util.NavigableMapReturns a key-value mapping associated with the least key greater than or equal to the given key, ornullif there is no such key.- Specified by:
- ceilingEntryin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Parameters:
- key- the key
- Returns:
- an entry with the least key greater than or equal to
         key, ornullif there is no such key
 
 - 
standardCeilingEntry@CheckForNull protected Map.Entry<K,V> standardCeilingEntry(K key) A sensible definition ofceilingEntry(K)in terms of thefirstEntry()oftailMap(Object, boolean). If you overridetailMap, you may wish to overrideceilingEntryto forward to this implementation.
 - 
ceilingKey@CheckForNull public K ceilingKey(K key) Description copied from interface:java.util.NavigableMapReturns the least key greater than or equal to the given key, ornullif there is no such key.- Specified by:
- ceilingKeyin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Parameters:
- key- the key
- Returns:
- the least key greater than or equal to key, ornullif there is no such key
 
 - 
standardCeilingKey@CheckForNull protected K standardCeilingKey(K key) A sensible definition ofceilingKey(K)in terms ofceilingEntry. If you overrideceilingEntry, you may wish to overrideceilingKeyto forward to this implementation.
 - 
higherEntry@CheckForNull public Map.Entry<K,V> higherEntry(K key) Description copied from interface:java.util.NavigableMapReturns a key-value mapping associated with the least key strictly greater than the given key, ornullif there is no such key.- Specified by:
- higherEntryin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Parameters:
- key- the key
- Returns:
- an entry with the least key greater than key, ornullif there is no such key
 
 - 
standardHigherEntry@CheckForNull protected Map.Entry<K,V> standardHigherEntry(K key) A sensible definition ofhigherEntry(K)in terms of thefirstEntry()oftailMap(Object, boolean). If you overridetailMap, you may wish to overridehigherEntryto forward to this implementation.
 - 
higherKey@CheckForNull public K higherKey(K key) Description copied from interface:java.util.NavigableMapReturns the least key strictly greater than the given key, ornullif there is no such key.
 - 
standardHigherKey@CheckForNull protected K standardHigherKey(K key) A sensible definition ofhigherKey(K)in terms ofhigherEntry. If you overridehigherEntry, you may wish to overridehigherKeyto forward to this implementation.
 - 
firstEntry@CheckForNull public Map.Entry<K,V> firstEntry() Description copied from interface:java.util.NavigableMapReturns a key-value mapping associated with the least key in this map, ornullif the map is empty.- Specified by:
- firstEntryin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Returns:
- an entry with the least key,
         or nullif this map is empty
 
 - 
standardFirstEntry@CheckForNull protected Map.Entry<K,V> standardFirstEntry() A sensible definition offirstEntry()in terms of theiterator()ofForwardingMap.entrySet(). If you overrideentrySet, you may wish to overridefirstEntryto forward to this implementation.
 - 
standardFirstKeyprotected K standardFirstKey() A sensible definition ofForwardingSortedMap.firstKey()in terms offirstEntry. If you overridefirstEntry, you may wish to overridefirstKeyto forward to this implementation.
 - 
lastEntry@CheckForNull public Map.Entry<K,V> lastEntry() Description copied from interface:java.util.NavigableMapReturns a key-value mapping associated with the greatest key in this map, ornullif the map is empty.
 - 
standardLastEntry@CheckForNull protected Map.Entry<K,V> standardLastEntry() A sensible definition oflastEntry()in terms of theiterator()of theForwardingMap.entrySet()ofdescendingMap(). If you overridedescendingMap, you may wish to overridelastEntryto forward to this implementation.
 - 
standardLastKeyprotected K standardLastKey() A sensible definition ofForwardingSortedMap.lastKey()in terms oflastEntry. If you overridelastEntry, you may wish to overridelastKeyto forward to this implementation.
 - 
pollFirstEntry@CheckForNull public Map.Entry<K,V> pollFirstEntry() Description copied from interface:java.util.NavigableMapRemoves and returns a key-value mapping associated with the least key in this map, ornullif the map is empty.- Specified by:
- pollFirstEntryin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Returns:
- the removed first entry of this map,
         or nullif this map is empty
 
 - 
standardPollFirstEntry@CheckForNull protected Map.Entry<K,V> standardPollFirstEntry() A sensible definition ofpollFirstEntry()in terms of theiteratorofentrySet. If you overrideentrySet, you may wish to overridepollFirstEntryto forward to this implementation.
 - 
pollLastEntry@CheckForNull public Map.Entry<K,V> pollLastEntry() Description copied from interface:java.util.NavigableMapRemoves and returns a key-value mapping associated with the greatest key in this map, ornullif the map is empty.- Specified by:
- pollLastEntryin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Returns:
- the removed last entry of this map,
         or nullif this map is empty
 
 - 
standardPollLastEntry@CheckForNull protected Map.Entry<K,V> standardPollLastEntry() A sensible definition ofpollFirstEntry()in terms of theiteratorof theentrySetofdescendingMap. If you overridedescendingMap, you may wish to overridepollFirstEntryto forward to this implementation.
 - 
descendingMappublic NavigableMap<K,V> descendingMap() Description copied from interface:java.util.NavigableMapReturns a reverse order view of the mappings contained in this map. The descending map is backed by this map, so changes to the map are reflected in the descending map, and vice-versa. If either map is modified while an iteration over a collection view of either map is in progress (except through the iterator's ownremoveoperation), the results of the iteration are undefined.The returned map has an ordering equivalent to Collections.reverseOrder(comparator()). The expressionm.descendingMap().descendingMap()returns a view ofmessentially equivalent tom.- Specified by:
- descendingMapin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Returns:
- a reverse order view of this map
 
 - 
navigableKeySetpublic NavigableSet<K> navigableKeySet() Description copied from interface:java.util.NavigableMapReturns aNavigableSetview of the keys contained in this map. The set's iterator returns the keys in ascending order. The set is backed by the map, so changes to the map are reflected in the set, and vice-versa. If the map is modified while an iteration over the set is in progress (except through the iterator's ownremoveoperation), the results of the iteration are undefined. The set supports element removal, which removes the corresponding mapping from the map, via theIterator.remove,Set.remove,removeAll,retainAll, andclearoperations. It does not support theaddoraddAlloperations.- Specified by:
- navigableKeySetin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Returns:
- a navigable set view of the keys in this map
 
 - 
descendingKeySetpublic NavigableSet<K> descendingKeySet() Description copied from interface:java.util.NavigableMapReturns a reverse orderNavigableSetview of the keys contained in this map. The set's iterator returns the keys in descending order. The set is backed by the map, so changes to the map are reflected in the set, and vice-versa. If the map is modified while an iteration over the set is in progress (except through the iterator's ownremoveoperation), the results of the iteration are undefined. The set supports element removal, which removes the corresponding mapping from the map, via theIterator.remove,Set.remove,removeAll,retainAll, andclearoperations. It does not support theaddoraddAlloperations.- Specified by:
- descendingKeySetin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Returns:
- a reverse order navigable set view of the keys in this map
 
 - 
standardDescendingKeySet@Beta protected NavigableSet<K> standardDescendingKeySet() A sensible definition ofdescendingKeySet()as thenavigableKeySetofdescendingMap(). (TheForwardingNavigableMap.StandardDescendingMapimplementation implementsnavigableKeySeton its own, so as not to cause an infinite loop.) If you overridedescendingMap, you may wish to overridedescendingKeySetto forward to this implementation.
 - 
standardSubMapprotected SortedMap<K,V> standardSubMap(K fromKey, K toKey) A sensible definition ofForwardingSortedMap.subMap(Object, Object)in terms ofsubMap(Object, boolean, Object, boolean). If you overridesubMap(K, boolean, K, boolean), you may wish to overridesubMapto forward to this implementation.- Overrides:
- standardSubMapin class- ForwardingSortedMap<K extends @Nullable Object,V extends @Nullable Object>
 
 - 
subMappublic NavigableMap<K,V> subMap(K fromKey, boolean fromInclusive, K toKey, boolean toInclusive) Description copied from interface:java.util.NavigableMapReturns a view of the portion of this map whose keys range fromfromKeytotoKey. IffromKeyandtoKeyare equal, the returned map is empty unlessfromInclusiveandtoInclusiveare both true. The returned map is backed by this map, so changes in the returned map are reflected in this map, and vice-versa. The returned map supports all optional map operations that this map supports.The returned map will throw an IllegalArgumentExceptionon an attempt to insert a key outside of its range, or to construct a submap either of whose endpoints lie outside its range.- Specified by:
- subMapin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Parameters:
- fromKey- low endpoint of the keys in the returned map
- fromInclusive-- trueif the low endpoint is to be included in the returned view
- toKey- high endpoint of the keys in the returned map
- toInclusive-- trueif the high endpoint is to be included in the returned view
- Returns:
- a view of the portion of this map whose keys range from
         fromKeytotoKey
 
 - 
headMappublic NavigableMap<K,V> headMap(K toKey, boolean inclusive) Description copied from interface:java.util.NavigableMapReturns a view of the portion of this map whose keys are less than (or equal to, ifinclusiveis true)toKey. The returned map is backed by this map, so changes in the returned map are reflected in this map, and vice-versa. The returned map supports all optional map operations that this map supports.The returned map will throw an IllegalArgumentExceptionon an attempt to insert a key outside its range.- Specified by:
- headMapin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Parameters:
- toKey- high endpoint of the keys in the returned map
- inclusive-- trueif the high endpoint is to be included in the returned view
- Returns:
- a view of the portion of this map whose keys are less than
         (or equal to, if inclusiveis true)toKey
 
 - 
tailMappublic NavigableMap<K,V> tailMap(K fromKey, boolean inclusive) Description copied from interface:java.util.NavigableMapReturns a view of the portion of this map whose keys are greater than (or equal to, ifinclusiveis true)fromKey. The returned map is backed by this map, so changes in the returned map are reflected in this map, and vice-versa. The returned map supports all optional map operations that this map supports.The returned map will throw an IllegalArgumentExceptionon an attempt to insert a key outside its range.- Specified by:
- tailMapin interface- NavigableMap<K extends @Nullable Object,V extends @Nullable Object>
- Parameters:
- fromKey- low endpoint of the keys in the returned map
- inclusive-- trueif the low endpoint is to be included in the returned view
- Returns:
- a view of the portion of this map whose keys are greater than
         (or equal to, if inclusiveis true)fromKey
 
 - 
standardHeadMapprotected SortedMap<K,V> standardHeadMap(K toKey) A sensible definition ofForwardingSortedMap.headMap(Object)in terms ofheadMap(Object, boolean). If you overrideheadMap(K, boolean), you may wish to overrideheadMapto forward to this implementation.
 - 
standardTailMapprotected SortedMap<K,V> standardTailMap(K fromKey) A sensible definition ofForwardingSortedMap.tailMap(Object)in terms oftailMap(Object, boolean). If you overridetailMap(K, boolean), you may wish to overridetailMapto forward to this implementation.
 
- 
 
-