Class IndexedTreeMap<K,V>
- java.lang.Object
-
- de.gsi.dataset.utils.trees.AbstractMap<K,V>
-
- de.gsi.dataset.utils.trees.IndexedTreeMap<K,V>
-
- Type Parameters:
K- the type of keys maintained by this mapV- the type of mapped values
- All Implemented Interfaces:
IndexedNavigableMap<K,V>,java.io.Serializable,java.lang.Cloneable,java.util.Map<K,V>,java.util.NavigableMap<K,V>,java.util.SortedMap<K,V>
public class IndexedTreeMap<K,V> extends AbstractMap<K,V> implements IndexedNavigableMap<K,V>, java.lang.Cloneable, java.io.Serializable
A Red-Black tree based
NavigableMapimplementation. The map is sorted according to the natural ordering of its keys, or by aComparatorprovided at map creation time, depending on which constructor is used.This implementation provides guaranteed log(n) time cost for the
containsKey,get,putandremoveoperations. Algorithms are adaptations of those in Cormen, Leiserson, and Rivest's Introduction to Algorithms.Note that the ordering maintained by a sorted map (whether or not an explicit comparator is provided) must be consistent with equals if this sorted map is to correctly implement the
Mapinterface. (SeeComparableorComparatorfor a precise definition of consistent with equals.) This is so because theMapinterface is defined in terms of the equals operation, but a map performs all key comparisons using itscompareTo(orcompare) method, so two keys that are deemed equal by this method are, from the standpoint of the sorted map, equal. The behaviour of a sorted map is well-defined even if its ordering is inconsistent with equals; it just fails to obey the general contract of theMapinterface.Note that this implementation is not synchronised. If multiple threads access a map concurrently, and at least one of the threads modifies the map structurally, it must be synchronized externally. (A structural modification is any operation that adds or deletes one or more mappings; merely changing the value associated with an existing key is not a structural modification.) This is typically accomplished by synchronising on some object that naturally encapsulates the map. If no such object exists, the map should be "wrapped" using the
Collections.synchronizedSortedMapmethod. This is best done at creation time, to prevent accidental unsynchronised access to the map:SortedMap m = Collections.synchronizedSortedMap(new IndexedTreeMap(...));
The iterators returned by the
iteratormethod of the collections returned by all of this class's "collection view methods" are fail-fast: if the map is structurally modified at any time after the iterator is created, in any way except through the iterator's ownremovemethod, the iterator will throw aConcurrentModificationException. Thus, in the face of concurrent modification, the iterator fails quickly and cleanly, rather than risking arbitrary, non-deterministic behaviour at an undetermined time in the future.Note that the fail-fast behaviour of an iterator cannot be guaranteed as it is, generally speaking, impossible to make any hard guarantees in the presence of unsynchronised concurrent modification. Fail-fast iterators throw
ConcurrentModificationExceptionon a best-effort basis. Therefore, it would be wrong to write a program that depended on this exception for its correctness: the fail-fast behaviour of iterators should be used only to detect bugs.All
Map.Entrypairs returned by methods in this class and its views represent snapshots of mappings at the time they were produced. They do not support theEntry.setValuemethod. (Note however that it is possible to change mappings in the associated map usingput.)This class is a member of the Java Collections Framework.
- Since:
- 1.2
- Version:
- 1.73, 05/10/06
- Author:
- Josh Bloch, Doug Lea, Vitaly Sazanovich
- See Also:
Map,HashMap,Hashtable,Comparable,Comparator,Collection, Serialized Form
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description protected static classIndexedTreeMap.AscendingSubMap<K,V>protected static classIndexedTreeMap.Entry<K,V>Node in the Tree.protected classIndexedTreeMap.EntryIteratorprotected classIndexedTreeMap.PrivateEntryIterator<T>Base class for IndexedTreeMap Iteratorsprotected classIndexedTreeMap.ValueIterator-
Nested classes/interfaces inherited from class de.gsi.dataset.utils.trees.AbstractMap
AbstractMap.SimpleEntry<K,V>, AbstractMap.SimpleImmutableEntry<K,V>
-
-
Constructor Summary
Constructors Constructor Description IndexedTreeMap()Constructs a new, empty tree map, using the natural ordering of its keys.IndexedTreeMap(java.util.Comparator<? super K> comparator)Constructs a new, empty tree map, ordered according to the given comparator.IndexedTreeMap(java.util.Map<? extends K,? extends V> m)Constructs a new tree map containing the same mappings as the given map, ordered according to the natural ordering of its keys.IndexedTreeMap(java.util.SortedMap<K,? extends V> m)Constructs a new tree map containing the same mappings and using the same ordering as the specified sorted map.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddAllForTreeSet(java.util.SortedSet<? extends K> set, V defaultVal)Intended to be called only from IndexedTreeSet.addAlljava.util.Map.Entry<K,V>ceilingEntry(K key)KceilingKey(K key)voidclear()Removes all of the mappings from this map.java.lang.Objectclone()Returns a shallow copy of thisIndexedTreeMapinstance.java.util.Comparator<? super K>comparator()intcompare(java.lang.Object k1, java.lang.Object k2)Compares two keys using the correct comparison method for this IndexedTreeMap.booleancontainsKey(java.lang.Object key)Returnstrueif this map contains a mapping for the specified key.booleancontainsValue(java.lang.Object value)Returnstrueif this map maps one or more keys to the specified value.voiddbg()for debugging purposesvoiddebug()for debugging purposesjava.util.Iterator<K>descendingKeyIterator()java.util.NavigableSet<K>descendingKeySet()java.util.NavigableMap<K,V>descendingMap()java.util.Set<java.util.Map.Entry<K,V>>entrySet()Returns aSetview of the mappings contained in this map.IndexedTreeMap.Entry<K,V>exactEntry(int index)Returns a key-value mapping associated with the key located at the index offset from the beginning of the sorted mapKexactKey(int index)Returns the key located at the index offset from the beginning of the sorted mapstatic <K,V>
java.util.Map.Entry<K,V>exportEntry(IndexedTreeMap.Entry<K,V> e)Return SimpleImmutableEntry for entry, or null if nulljava.util.Map.Entry<K,V>firstEntry()KfirstKey()java.util.Map.Entry<K,V>floorEntry(K key)KfloorKey(K key)Vget(java.lang.Object key)Returns the value to which the specified key is mapped, ornullif this map contains no mapping for the key.IndexedTreeMap.Entry<K,V>getCeilingEntry(K key)Gets the entry corresponding to the specified key; if no such entry exists, returns the entry for the least key greater than the specified key; if no such entry exists (i.e., the greatest key in the Tree is less than the specified key), returnsnull.IndexedTreeMap.Entry<K,V>getEntry(K key)Returns this map's entry for the given key, ornullif the map does not contain an entry for the key.IndexedTreeMap.Entry<K,V>getEntryUsingComparator(K key)Version of getEntry using comparator.IndexedTreeMap.Entry<K,V>getFirstEntry()Returns the first Entry in the IndexedTreeMap (according to the IndexedTreeMap's key-sort function).IndexedTreeMap.Entry<K,V>getFloorEntry(K key)Gets the entry corresponding to the specified key; if no such entry exists, returns the entry for the greatest key less than the specified key; if no such entry exists, returnsnull.IndexedTreeMap.Entry<K,V>getHigherEntry(K key)Gets the entry for the least key greater than the specified key; if no such entry exists, returns the entry for the least key greater than the specified key; if no such entry exists returnsnull.IndexedTreeMap.Entry<K,V>getLastEntry()Returns the last Entry in the IndexedTreeMap (according to the IndexedTreeMap's key-sort function).IndexedTreeMap.Entry<K,V>getLowerEntry(K key)Returns the entry for the greatest key less than the specified key; if no such entry exists (i.e., the least key in the Tree is greater than the specified key), returnsnull.java.util.SortedMap<K,V>headMap(K toKey)java.util.NavigableMap<K,V>headMap(K toKey, boolean inclusive)java.util.Map.Entry<K,V>higherEntry(K key)KhigherKey(K key)static <K> Kkey(IndexedTreeMap.Entry<K,?> e)Returns the key corresponding to the specified Entry.intkeyIndex(K key)Searches the specified tree map for the specified key using the put algorithm.java.util.Iterator<K>keyIterator()static <K,V>
KkeyOrNull(IndexedTreeMap.Entry<K,V> e)Return key for entry, or null if nulljava.util.Set<K>keySet()Returns aSetview of the keys contained in this map.java.util.Map.Entry<K,V>lastEntry()KlastKey()java.util.Map.Entry<K,V>lowerEntry(K key)KlowerKey(K key)java.util.NavigableSet<K>navigableKeySet()java.util.Map.Entry<K,V>pollFirstEntry()java.util.Map.Entry<K,V>pollLastEntry()static <K,V>
IndexedTreeMap.Entry<K,V>predecessor(IndexedTreeMap.Entry<K,V> t)Returns the predecessor of the specified Entry, or null if no such.Vput(K key, V value)Associates the specified value with the specified key in this map.voidputAll(java.util.Map<? extends K,? extends V> map)Copies all of the mappings from the specified map to this map.voidreadTreeSet(int size, java.io.ObjectInputStream s, V defaultVal)Intended to be called only from IndexedTreeSet.readObjectVremove(java.lang.Object key)Removes the mapping for this key from this IndexedTreeMap if present.intsize()Returns the number of key-value mappings in this map.java.util.NavigableMap<K,V>subMap(K fromKey, boolean fromInclusive, K toKey, boolean toInclusive)java.util.SortedMap<K,V>subMap(K fromKey, K toKey)static <K,V>
IndexedTreeMap.Entry<K,V>successor(IndexedTreeMap.Entry<K,V> t)Returns the successor of the specified Entry, or null if no such.java.util.SortedMap<K,V>tailMap(K fromKey)java.util.NavigableMap<K,V>tailMap(K fromKey, boolean inclusive)static booleanvalEquals(java.lang.Object o1, java.lang.Object o2)Test two values for equality.java.util.Collection<V>values()Returns aCollectionview of the values contained in this map.-
Methods inherited from class de.gsi.dataset.utils.trees.AbstractMap
equals, hashCode, isEmpty, toString
-
-
-
-
Constructor Detail
-
IndexedTreeMap
public IndexedTreeMap()
Constructs a new, empty tree map, using the natural ordering of its keys. All keys inserted into the map must implement theComparableinterface. Furthermore, all such keys must be mutually comparable:k1.compareTo(k2)must not throw aClassCastExceptionfor any keysk1andk2in the map. If the user attempts to put a key into the map that violates this constraint (for example, the user attempts to put a string key into a map whose keys are integers), theput(Object key, Object value)call will throw aClassCastException.
-
IndexedTreeMap
public IndexedTreeMap(java.util.Comparator<? super K> comparator)
Constructs a new, empty tree map, ordered according to the given comparator. All keys inserted into the map must be mutually comparable by the given comparator:comparator.compare(k1, k2)must not throw aClassCastExceptionfor any keysk1andk2in the map. If the user attempts to put a key into the map that violates this constraint, theput(Object key, Object value)call will throw aClassCastException.- Parameters:
comparator- the comparator that will be used to order this map. Ifnull, the natural ordering of the keys will be used.
-
IndexedTreeMap
public IndexedTreeMap(java.util.Map<? extends K,? extends V> m)
Constructs a new tree map containing the same mappings as the given map, ordered according to the natural ordering of its keys. All keys inserted into the new map must implement theComparableinterface. Furthermore, all such keys must be mutually comparable:k1.compareTo(k2)must not throw aClassCastExceptionfor any keysk1andk2in the map. This method runs in n*log(n) time.- Parameters:
m- the map whose mappings are to be placed in this map- Throws:
java.lang.ClassCastException- if the keys in m are notComparable, or are not mutually comparablejava.lang.NullPointerException- if the specified map is null
-
IndexedTreeMap
public IndexedTreeMap(java.util.SortedMap<K,? extends V> m)
Constructs a new tree map containing the same mappings and using the same ordering as the specified sorted map. This method runs in linear time.- Parameters:
m- the sorted map whose mappings are to be placed in this map, and whose comparator is to be used to sort this map- Throws:
java.lang.NullPointerException- if the specified map is null
-
-
Method Detail
-
addAllForTreeSet
public void addAllForTreeSet(java.util.SortedSet<? extends K> set, V defaultVal)
Intended to be called only from IndexedTreeSet.addAll- Parameters:
set- ???defaultVal- ???
-
clear
public void clear()
Removes all of the mappings from this map. The map will be empty after this call returns.
-
clone
public java.lang.Object clone()
Returns a shallow copy of thisIndexedTreeMapinstance. (The keys and values themselves are not cloned.)- Overrides:
clonein classAbstractMap<K,V>- Returns:
- a shallow copy of this map
-
comparator
public java.util.Comparator<? super K> comparator()
-
compare
public final int compare(java.lang.Object k1, java.lang.Object k2)Compares two keys using the correct comparison method for this IndexedTreeMap.- Parameters:
k1- object1 to be comparedk2- object2 to be compared- Returns:
- true if equal
-
containsKey
public boolean containsKey(java.lang.Object key)
Returnstrueif this map contains a mapping for the specified key.- Specified by:
containsKeyin interfacejava.util.Map<K,V>- Overrides:
containsKeyin classAbstractMap<K,V>- Parameters:
key- key whose presence in this map is to be tested- Returns:
trueif this map contains a mapping for the specified key- Throws:
java.lang.ClassCastException- if the specified key cannot be compared with the keys currently in the mapjava.lang.NullPointerException- if the specified key is null and this map uses natural ordering, or its comparator does not permit null keys
-
containsValue
public boolean containsValue(java.lang.Object value)
Returnstrueif this map maps one or more keys to the specified value. More formally, returnstrueif and only if this map contains at least one mapping to a valuevsuch that(value==null ? v==null : value.equals(v)). This operation will probably require time linear in the map size for most implementations.- Specified by:
containsValuein interfacejava.util.Map<K,V>- Overrides:
containsValuein classAbstractMap<K,V>- Parameters:
value- value whose presence in this map is to be tested- Returns:
trueif a mapping tovalueexists;falseotherwise- Since:
- 1.2
-
dbg
public void dbg()
for debugging purposes
-
debug
public void debug() throws java.lang.Exceptionfor debugging purposes- Throws:
java.lang.Exception- if weight is incorrect
-
descendingKeyIterator
public java.util.Iterator<K> descendingKeyIterator()
-
descendingKeySet
public java.util.NavigableSet<K> descendingKeySet()
-
entrySet
public java.util.Set<java.util.Map.Entry<K,V>> entrySet()
Returns aSetview of the mappings contained in this map. The set's iterator returns the entries in ascending key 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, or through thesetValueoperation on a map entry returned by the iterator) 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,retainAllandclearoperations. It does not support theaddoraddAlloperations.
-
exactEntry
public IndexedTreeMap.Entry<K,V> exactEntry(int index)
Description copied from interface:IndexedNavigableMapReturns a key-value mapping associated with the key located at the index offset from the beginning of the sorted map- Specified by:
exactEntryin interfaceIndexedNavigableMap<K,V>- Parameters:
index- index of the key- Returns:
- the entry with the key
keylocated at the index (@code index) offset from the beginning of the sorted map
-
exactKey
public K exactKey(int index)
Description copied from interface:IndexedNavigableMapReturns the key located at the index offset from the beginning of the sorted map- Specified by:
exactKeyin interfaceIndexedNavigableMap<K,V>- Parameters:
index- index of the key- Returns:
- the key
keylocated at the index (@code index) offset from the beginning of the sorted map
-
firstKey
public K firstKey()
-
get
public V get(java.lang.Object key)
Returns the value to which the specified key is mapped, ornullif this map contains no mapping for the key. More formally, if this map contains a mapping from a keykto a valuevsuch thatkeycompares equal tokaccording to the map's ordering, then this method returnsv; otherwise it returnsnull. (There can be at most one such mapping.) A return value ofnulldoes not necessarily indicate that the map contains no mapping for the key; it's also possible that the map explicitly maps the key tonull. ThecontainsKeyoperation may be used to distinguish these two cases.- Specified by:
getin interfacejava.util.Map<K,V>- Overrides:
getin classAbstractMap<K,V>- Throws:
java.lang.ClassCastException- if the specified key cannot be compared with the keys currently in the mapjava.lang.NullPointerException- if the specified key is null and this map uses natural ordering, or its comparator does not permit null keys
-
getCeilingEntry
public final IndexedTreeMap.Entry<K,V> getCeilingEntry(K key)
Gets the entry corresponding to the specified key; if no such entry exists, returns the entry for the least key greater than the specified key; if no such entry exists (i.e., the greatest key in the Tree is less than the specified key), returnsnull.- Parameters:
key- key value- Returns:
- entry
-
getEntry
public final IndexedTreeMap.Entry<K,V> getEntry(K key)
Returns this map's entry for the given key, ornullif the map does not contain an entry for the key.- Parameters:
key- key value- Returns:
- this map's entry for the given key, or
nullif the map does not contain an entry for the key - Throws:
java.lang.ClassCastException- if the specified key cannot be compared with the keys currently in the mapjava.lang.NullPointerException- if the specified key is null and this map uses natural ordering, or its comparator does not permit null keys
-
getEntryUsingComparator
public final IndexedTreeMap.Entry<K,V> getEntryUsingComparator(K key)
Version of getEntry using comparator. Split off from getEntry for performance. (This is not worth doing for most methods, that are less dependent on comparator performance, but is worthwhile here.)- Parameters:
key- key value- Returns:
- entry
-
getFirstEntry
public final IndexedTreeMap.Entry<K,V> getFirstEntry()
Returns the first Entry in the IndexedTreeMap (according to the IndexedTreeMap's key-sort function). Returns null if the IndexedTreeMap is empty.- Returns:
- entry
-
getFloorEntry
public final IndexedTreeMap.Entry<K,V> getFloorEntry(K key)
Gets the entry corresponding to the specified key; if no such entry exists, returns the entry for the greatest key less than the specified key; if no such entry exists, returnsnull.- Parameters:
key- key value- Returns:
- entry
-
getHigherEntry
public final IndexedTreeMap.Entry<K,V> getHigherEntry(K key)
Gets the entry for the least key greater than the specified key; if no such entry exists, returns the entry for the least key greater than the specified key; if no such entry exists returnsnull.- Parameters:
key- key value- Returns:
- entry
-
getLastEntry
public final IndexedTreeMap.Entry<K,V> getLastEntry()
Returns the last Entry in the IndexedTreeMap (according to the IndexedTreeMap's key-sort function). Returns null if the IndexedTreeMap is empty.- Returns:
- entry
-
getLowerEntry
public final IndexedTreeMap.Entry<K,V> getLowerEntry(K key)
Returns the entry for the greatest key less than the specified key; if no such entry exists (i.e., the least key in the Tree is greater than the specified key), returnsnull.- Parameters:
key- key value- Returns:
- entry
-
headMap
public java.util.SortedMap<K,V> headMap(K toKey)
- Specified by:
headMapin interfacejava.util.NavigableMap<K,V>- Specified by:
headMapin interfacejava.util.SortedMap<K,V>- Throws:
java.lang.ClassCastExceptionjava.lang.NullPointerException- iftoKeyis null and this map uses natural ordering, or its comparator does not permit null keysjava.lang.IllegalArgumentException
-
keyIndex
public int keyIndex(K key)
Description copied from interface:IndexedNavigableMapSearches the specified tree map for the specified key using the put algorithm. Calculates its offset from the beginning of the sorted map using weights.- Specified by:
keyIndexin interfaceIndexedNavigableMap<K,V>- Parameters:
key- the key- Returns:
- index of the search key, if it is contained in the tree map; otherwise a NullPointerException is thrown
-
keyIterator
public java.util.Iterator<K> keyIterator()
-
keySet
public java.util.Set<K> keySet()
Returns aSetview 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.
-
lastKey
public K lastKey()
-
navigableKeySet
public java.util.NavigableSet<K> navigableKeySet()
-
put
public V put(K key, V value)
Associates the specified value with the specified key in this map. If the map previously contained a mapping for the key, the old value is replaced.- Specified by:
putin interfacejava.util.Map<K,V>- Overrides:
putin classAbstractMap<K,V>- Parameters:
key- key with which the specified value is to be associatedvalue- value to be associated with the specified key- Returns:
- the previous value associated with
key, ornullif there was no mapping forkey. (Anullreturn can also indicate that the map previously associatednullwithkey.) - Throws:
java.lang.ClassCastException- if the specified key cannot be compared with the keys currently in the mapjava.lang.NullPointerException- if the specified key is null and this map uses natural ordering, or its comparator does not permit null keys
-
putAll
public void putAll(java.util.Map<? extends K,? extends V> map)
Copies all of the mappings from the specified map to this map. These mappings replace any mappings that this map had for any of the keys currently in the specified map.- Specified by:
putAllin interfacejava.util.Map<K,V>- Overrides:
putAllin classAbstractMap<K,V>- Parameters:
map- mappings to be stored in this map- Throws:
java.lang.ClassCastException- if the class of a key or value in the specified map prevents it from being stored in this mapjava.lang.NullPointerException- if the specified map is null or the specified map contains a null key and this map does not permit null keys
-
readTreeSet
public void readTreeSet(int size, java.io.ObjectInputStream s, V defaultVal) throws java.io.IOException, java.lang.ClassNotFoundExceptionIntended to be called only from IndexedTreeSet.readObject- Parameters:
size- ???s- output streamdefaultVal- ???- Throws:
java.io.IOException- in case of write errorsjava.lang.ClassNotFoundException- in case of class casting errors
-
remove
public V remove(java.lang.Object key)
Removes the mapping for this key from this IndexedTreeMap if present.- Specified by:
removein interfacejava.util.Map<K,V>- Overrides:
removein classAbstractMap<K,V>- Parameters:
key- key for which mapping should be removed- Returns:
- the previous value associated with
key, ornullif there was no mapping forkey. (Anullreturn can also indicate that the map previously associatednullwithkey.) - Throws:
java.lang.ClassCastException- if the specified key cannot be compared with the keys currently in the mapjava.lang.NullPointerException- if the specified key is null and this map uses natural ordering, or its comparator does not permit null keys
-
size
public int size()
Returns the number of key-value mappings in this map.
-
subMap
public java.util.NavigableMap<K,V> subMap(K fromKey, boolean fromInclusive, K toKey, boolean toInclusive)
-
subMap
public java.util.SortedMap<K,V> subMap(K fromKey, K toKey)
- Specified by:
subMapin interfacejava.util.NavigableMap<K,V>- Specified by:
subMapin interfacejava.util.SortedMap<K,V>- Throws:
java.lang.ClassCastExceptionjava.lang.NullPointerException- iffromKeyortoKeyis null and this map uses natural ordering, or its comparator does not permit null keysjava.lang.IllegalArgumentException
-
tailMap
public java.util.SortedMap<K,V> tailMap(K fromKey)
- Specified by:
tailMapin interfacejava.util.NavigableMap<K,V>- Specified by:
tailMapin interfacejava.util.SortedMap<K,V>- Throws:
java.lang.ClassCastExceptionjava.lang.NullPointerException- iffromKeyis null and this map uses natural ordering, or its comparator does not permit null keysjava.lang.IllegalArgumentException
-
values
public java.util.Collection<V> values()
Returns aCollectionview of the values contained in this map. The collection's iterator returns the values in ascending order of the corresponding keys. The collection is backed by the map, so changes to the map are reflected in the collection, and vice-versa. If the map is modified while an iteration over the collection is in progress (except through the iterator's ownremoveoperation), the results of the iteration are undefined. The collection supports element removal, which removes the corresponding mapping from the map, via theIterator.remove,Collection.remove,removeAll,retainAllandclearoperations. It does not support theaddoraddAlloperations.
-
exportEntry
public static <K,V> java.util.Map.Entry<K,V> exportEntry(IndexedTreeMap.Entry<K,V> e)
Return SimpleImmutableEntry for entry, or null if null- Type Parameters:
K- key value typeV- value value type- Parameters:
e- entry to be searched- Returns:
- entry
-
key
public static <K> K key(IndexedTreeMap.Entry<K,?> e)
Returns the key corresponding to the specified Entry.- Type Parameters:
K- key value type- Parameters:
e- entry to be searched- Returns:
- key
- Throws:
java.util.NoSuchElementException- if the Entry is null
-
keyOrNull
public static <K,V> K keyOrNull(IndexedTreeMap.Entry<K,V> e)
Return key for entry, or null if null- Type Parameters:
K- key value typeV- value value type- Parameters:
e- entry to be searched- Returns:
- key
-
predecessor
public static <K,V> IndexedTreeMap.Entry<K,V> predecessor(IndexedTreeMap.Entry<K,V> t)
Returns the predecessor of the specified Entry, or null if no such.- Type Parameters:
K- key value typeV- value type- Parameters:
t- entry- Returns:
- predecessor entry
-
successor
public static <K,V> IndexedTreeMap.Entry<K,V> successor(IndexedTreeMap.Entry<K,V> t)
Returns the successor of the specified Entry, or null if no such.- Type Parameters:
K- key value typeV- value type- Parameters:
t- entry- Returns:
- successor entry
-
valEquals
public static boolean valEquals(java.lang.Object o1, java.lang.Object o2)Test two values for equality. Differs from o1.equals(o2) only in that it copes withnullo1 properly.- Parameters:
o1- object1 to be comparedo2- object2 to be compared- Returns:
- true if equal
-
-