|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||
java.lang.Objectjava.util.AbstractMap<K,V>
com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap<K,V>
K - the type of keys maintained by this mapV - the type of mapped values@ThreadSafe public final class ConcurrentLinkedHashMap<K,V>
A hash table supporting full concurrency of retrievals, adjustable expected
concurrency for updates, and a maximum capacity to bound the map by. This
implementation differs from ConcurrentHashMap in that it maintains a
page replacement algorithm that is used to evict an entry when the map has
exceeded its capacity. Unlike the Java Collections Framework, this
map does not have a publicly visible constructor and instances are created
through a ConcurrentLinkedHashMap.Builder.
An entry is evicted from the map when the weighted capacity exceeds
the maximum weighted capacity threshold. A Weigher instance
determines how many units of capacity that a value consumes. The default
singleton weigher algorithm assigns each value a weight of 1 to
bound the map by the number of key-value pairs. A map that holds collections
may weigh values by the number of elements in the collection and bound the
map by the total number of elements it contains. A change to a value that
modifies its weight requires that an update operation is performed on the
map.
An EvictionListener may be supplied for notification when an entry is
evicted from the map. This listener is invoked on a caller's thread and will
not block other threads from operating on the map. An implementation should
be aware that the caller's thread will not expect long execution times or
failures as a side effect of the listener being notified. Execution safety
and a fast turn around time can be achieved by performing the operation
asynchronously, such as by submitting a task to an
ExecutorService.
The concurrency level determines the number of threads that can concurrently modify the table. Using a significantly higher or lower value than needed can waste space or lead to thread contention, but an estimate within an order of magnitude of the ideal value does not usually have a noticeable impact. Because placement in hash tables is essentially random, the actual concurrency will vary.
This class and its views and iterators implement all of the
optional methods of the Map and Iterator
interfaces.
Like Hashtable but unlike HashMap, this class
does not allow null to be used as a key or value.
| Nested Class Summary | |
|---|---|
static class |
ConcurrentLinkedHashMap.Builder<K,V>
A builder that creates ConcurrentLinkedHashMap instances and can
be used in the following manner:
ConcurrentMap<User, Set<Group>> groups = new Builder<User, Set<Group>>()
.weigher(Weighers.<Group>set())
.maximumWeightedCapacity(5000)
.build();
|
| Nested classes/interfaces inherited from class java.util.AbstractMap |
|---|
AbstractMap.SimpleImmutableEntry<K,V> |
| Nested classes/interfaces inherited from interface java.util.Map |
|---|
Map.Entry<K,V> |
| Method Summary | |
|---|---|
int |
capacity()
Retrieves the maximum weighted capacity of the map. |
void |
clear()
|
boolean |
containsKey(Object key)
|
boolean |
containsValue(Object value)
|
Set<Map.Entry<K,V>> |
entrySet()
|
V |
get(Object key)
|
boolean |
isEmpty()
|
Set<K> |
keySet()
|
V |
put(K key,
V value)
|
V |
putIfAbsent(K key,
V value)
|
V |
remove(Object key)
|
boolean |
remove(Object key,
Object value)
|
V |
replace(K key,
V value)
|
boolean |
replace(K key,
V oldValue,
V newValue)
|
void |
setCapacity(int capacity)
Sets the maximum weighted capacity of the map and eagerly evicts entries until it shrinks to the appropriate size. |
int |
size()
|
Collection<V> |
values()
|
int |
weightedSize()
Returns the weighted size in this map. |
| Methods inherited from class java.util.AbstractMap |
|---|
clone, equals, hashCode, putAll, toString |
| Methods inherited from class java.lang.Object |
|---|
finalize, getClass, notify, notifyAll, wait, wait, wait |
| Methods inherited from interface java.util.Map |
|---|
equals, hashCode, putAll |
| Method Detail |
|---|
public int capacity()
public void setCapacity(int capacity)
capacity - the maximum weighted capacity of the map
IllegalArgumentException - if the capacity is negativepublic boolean isEmpty()
isEmpty in interface Map<K,V>isEmpty in class AbstractMap<K,V>public int size()
size in interface Map<K,V>size in class AbstractMap<K,V>public int weightedSize()
public void clear()
clear in interface Map<K,V>clear in class AbstractMap<K,V>public boolean containsKey(Object key)
containsKey in interface Map<K,V>containsKey in class AbstractMap<K,V>public boolean containsValue(Object value)
containsValue in interface Map<K,V>containsValue in class AbstractMap<K,V>public V get(Object key)
get in interface Map<K,V>get in class AbstractMap<K,V>
public V put(K key,
V value)
put in interface Map<K,V>put in class AbstractMap<K,V>
public V putIfAbsent(K key,
V value)
putIfAbsent in interface ConcurrentMap<K,V>public V remove(Object key)
remove in interface Map<K,V>remove in class AbstractMap<K,V>
public boolean remove(Object key,
Object value)
remove in interface ConcurrentMap<K,V>
public V replace(K key,
V value)
replace in interface ConcurrentMap<K,V>
public boolean replace(K key,
V oldValue,
V newValue)
replace in interface ConcurrentMap<K,V>public Set<K> keySet()
keySet in interface Map<K,V>keySet in class AbstractMap<K,V>public Collection<V> values()
values in interface Map<K,V>values in class AbstractMap<K,V>public Set<Map.Entry<K,V>> entrySet()
entrySet in interface Map<K,V>entrySet in class AbstractMap<K,V>
|
|||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | ||||||||