java.lang.Object | |||
↳ | java.util.AbstractMap<K, V> | ||
↳ | java.util.HashMap<K, V> | ||
↳ | java.util.LinkedHashMap<K, V> |
LinkedHashMap is a variant of HashMap. Its entries are kept in a
doubly-linked list. The iteration order is, by default, the order in which
keys were inserted. Reinserting an already existing key doesn't change the
order. A key is existing if a call to containsKey
would return true.
If the three argument constructor is used, and order
is specified as
true
, the iteration will be in the order that entries were accessed.
The access order gets affected by put(), get(), putAll() operations, but not
by operations on the collection views.
Null elements are allowed, and all the optional map operations are supported.
Note: The implementation of LinkedHashMap
is not synchronized.
If one thread of several threads accessing an instance modifies the map
structurally, access to the map needs to be synchronized. For
insertion-ordered instances a structural modification is an operation that
removes or adds an entry. Access-ordered instances also are structurally
modified by put(), get() and putAll() since these methods change the order of
the entries. Changes in the value of an entry are not structural changes.
The Iterator that can be created by calling the iterator
method
throws a ConcurrentModificationException
if the map is structurally
changed while an iterator is used to iterate over the elements. Only the
remove
method that is provided by the iterator allows for removal of
elements during iteration. It is not possible to guarantee that this
mechanism works in all cases of unsynchronized concurrent modification. It
should only be used for debugging purposes.
Public Constructors | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Constructs a new empty
LinkedHashMap instance. | |||||||||||
Constructs a new
LinkedHashMap instance with the specified
capacity. | |||||||||||
Constructs a new
LinkedHashMap instance with the specified
capacity and load factor. | |||||||||||
Constructs a new
LinkedHashMap instance with the specified
capacity, load factor and a flag specifying the ordering behavior. | |||||||||||
Constructs a new
LinkedHashMap instance containing the mappings
from the specified map. |
Public Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Removes all elements from this map, leaving it empty.
| |||||||||||
Returns a set containing all of the mappings in this map.
| |||||||||||
Returns the value of the mapping with the specified key.
| |||||||||||
Returns a set of the keys contained in this map.
| |||||||||||
Maps the specified key to the specified value.
| |||||||||||
Removes the mapping with the specified key from this map.
| |||||||||||
Returns a collection of the values contained in this map.
|
Protected Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
This method is queried from the put and putAll methods to check if the
eldest member of the map should be deleted before adding the new member.
|
[Expand]
Inherited Methods | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
From class java.util.HashMap
| |||||||||||
From class java.util.AbstractMap
| |||||||||||
From class java.lang.Object
| |||||||||||
From interface java.util.Map
|
Constructs a new LinkedHashMap
instance with the specified
capacity.
s | the initial capacity of this map. |
---|
IllegalArgumentException | when the capacity is less than zero. |
---|
Constructs a new LinkedHashMap
instance with the specified
capacity and load factor.
s | the initial capacity of this map. |
---|---|
lf | the initial load factor. |
IllegalArgumentException | when the capacity is less than zero or the load factor is less or equal to zero. |
---|
Constructs a new LinkedHashMap
instance with the specified
capacity, load factor and a flag specifying the ordering behavior.
s | the initial capacity of this hash map. |
---|---|
lf | the initial load factor. |
order | true if the ordering should be done based on the last
access (from least-recently accessed to most-recently
accessed), and false if the ordering should be the
order in which the entries were inserted. |
IllegalArgumentException | when the capacity is less than zero or the load factor is less or equal to zero. |
---|
Constructs a new LinkedHashMap
instance containing the mappings
from the specified map. The order of the elements is preserved.
m | the mappings to add. |
---|
Returns a set containing all of the mappings in this map. Each mapping is an instance of Map.Entry. As the set is backed by this map, changes in one will be reflected in the other.
Returns the value of the mapping with the specified key.
key | the key. |
---|
null
if no mapping for the specified key is found.Returns a set of the keys contained in this map. The set is backed by this map so changes to one are reflected by the other. The set does not support adding.
Maps the specified key to the specified value.
key | the key. |
---|---|
value | the value. |
null
if there was no such mapping.Removes the mapping with the specified key from this map.
key | the key of the mapping to remove. |
---|
null
if no mapping
for the specified key was found.Returns a collection of the values contained in this map. The collection is backed by this map so changes to one are reflected by the other. The collection supports remove, removeAll, retainAll and clear operations, and it does not support add or addAll operations.
This method returns a collection which is the subclass of AbstractCollection. The iterator method of this subclass returns a "wrapper object" over the iterator of map's entrySet(). The size method wraps the map's size method and the contains method wraps the map's containsValue method.
The collection is created when this method is called for the first time and returned in response to all subsequent calls. This method may return different collections when multiple concurrent calls occur, since no synchronization is performed.
This method is queried from the put and putAll methods to check if the eldest member of the map should be deleted before adding the new member. If this map was created with accessOrder = true, then the result of removeEldestEntry is assumed to be false.
eldest | the entry to check if it should be removed. |
---|
true
if the eldest member should be removed.