|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectcom.google.common.collect.ForwardingObject
com.google.common.collect.ForwardingMap<K,V>
com.google.common.collect.ForwardingSortedMap<K,V>
@GwtCompatible public abstract class ForwardingSortedMap<K,V>
A sorted map which forwards all its method calls to another sorted map. Subclasses should override one or more methods to modify the behavior of the backing sorted map as desired per the decorator pattern.
Warning: The methods of ForwardingSortedMap forward
indiscriminately to the methods of the delegate. For example,
overriding ForwardingMap.put(K, V) alone will not change the behavior of ForwardingMap.putAll(java.util.Map extends K, ? extends V>), which can lead to unexpected behavior. In this case, you should
override putAll as well, either providing your own implementation, or
delegating to the provided standardPutAll method.
Each of the standard methods, where appropriate, use the
comparator of the map to test equality for both keys and values, unlike
ForwardingMap.
The standard methods 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.
| Nested Class Summary |
|---|
| Nested classes/interfaces inherited from interface java.util.Map |
|---|
Map.Entry<K,V> |
| Constructor Summary | |
|---|---|
protected |
ForwardingSortedMap()
Constructor for use by subclasses. |
| Method Summary | |
|---|---|
Comparator<? super K> |
comparator()
Returns the comparator used to order the keys in this map, or null if this map uses the natural ordering of its keys. |
protected abstract SortedMap<K,V> |
delegate()
Returns the backing delegate instance that methods are forwarded to. |
K |
firstKey()
Returns the first (lowest) key currently in this map. |
SortedMap<K,V> |
headMap(K toKey)
Returns a view of the portion of this map whose keys are strictly less than toKey. |
K |
lastKey()
Returns the last (highest) key currently in this map. |
protected boolean |
standardContainsKey(Object key)
A sensible definition of ForwardingMap.containsKey(java.lang.Object) in terms of the firstKey() method of tailMap(K). |
protected V |
standardRemove(Object key)
A sensible definition of ForwardingMap.remove(java.lang.Object) in terms of the iterator() of the entrySet() of tailMap(K). |
protected SortedMap<K,V> |
standardSubMap(K fromKey,
K toKey)
A sensible default implementation of subMap(Object, Object) in
terms of headMap(Object) and tailMap(Object). |
SortedMap<K,V> |
subMap(K fromKey,
K toKey)
Returns a view of the portion of this map whose keys range from fromKey, inclusive, to toKey, exclusive. |
SortedMap<K,V> |
tailMap(K fromKey)
Returns a view of the portion of this map whose keys are greater than or equal to fromKey. |
| Methods inherited from class com.google.common.collect.ForwardingMap |
|---|
clear, containsKey, containsValue, entrySet, equals, get, hashCode, isEmpty, keySet, put, putAll, remove, size, standardClear, standardContainsValue, standardEntrySet, standardEquals, standardHashCode, standardIsEmpty, standardKeySet, standardPutAll, standardToString, standardValues, values |
| Methods inherited from class com.google.common.collect.ForwardingObject |
|---|
toString |
| Methods inherited from class java.lang.Object |
|---|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait |
| Methods inherited from interface java.util.SortedMap |
|---|
entrySet, keySet, values |
| Methods inherited from interface java.util.Map |
|---|
clear, containsKey, containsValue, equals, get, hashCode, isEmpty, put, putAll, remove, size |
| Constructor Detail |
|---|
protected ForwardingSortedMap()
| Method Detail |
|---|
protected abstract SortedMap<K,V> delegate()
ForwardingObjectForwardingSet.delegate(). Concrete subclasses override this method to supply
the instance being decorated.
delegate in class ForwardingMap<K,V>public Comparator<? super K> comparator()
java.util.SortedMap
comparator in interface SortedMap<K,V>public K firstKey()
java.util.SortedMap
firstKey in interface SortedMap<K,V>public SortedMap<K,V> headMap(K toKey)
java.util.SortedMapThe returned map will throw an IllegalArgumentException on an attempt to insert a key outside its range.
headMap in interface SortedMap<K,V>toKey - high endpoint (exclusive) of the keys in the returned map
public K lastKey()
java.util.SortedMap
lastKey in interface SortedMap<K,V>
public SortedMap<K,V> subMap(K fromKey,
K toKey)
java.util.SortedMapThe returned map will throw an IllegalArgumentException on an attempt to insert a key outside its range.
subMap in interface SortedMap<K,V>fromKey - low endpoint (inclusive) of the keys in the returned maptoKey - high endpoint (exclusive) of the keys in the returned map
public SortedMap<K,V> tailMap(K fromKey)
java.util.SortedMapThe returned map will throw an IllegalArgumentException on an attempt to insert a key outside its range.
tailMap in interface SortedMap<K,V>fromKey - low endpoint (inclusive) of the keys in the returned map
@Beta
protected boolean standardContainsKey(@Nullable
Object key)
ForwardingMap.containsKey(java.lang.Object) in terms of the firstKey() method of tailMap(K). If you override tailMap(K),
you may wish to override ForwardingMap.containsKey(java.lang.Object) to forward to this
implementation.
standardContainsKey in class ForwardingMap<K,V>
@Beta
protected V standardRemove(@Nullable
Object key)
ForwardingMap.remove(java.lang.Object) in terms of the iterator() of the entrySet() of tailMap(K). If you override
tailMap(K), you may wish to override ForwardingMap.remove(java.lang.Object) to forward
to this implementation.
standardRemove in class ForwardingMap<K,V>
@Beta
protected SortedMap<K,V> standardSubMap(K fromKey,
K toKey)
subMap(Object, Object) in
terms of headMap(Object) and tailMap(Object). In some
situations, you may wish to override subMap(Object, Object) to
forward to this implementation.
|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||