Package it.unimi.dsi.fastutil.objects
Class Object2ReferenceMaps
java.lang.Object
it.unimi.dsi.fastutil.objects.Object2ReferenceMaps
A class providing static methods and objects that do useful things with type-specific maps.
- See Also:
-
Nested Class Summary
Modifier and TypeClassDescriptionstatic class
An immutable class representing an empty type-specific map.static class
An immutable class representing a type-specific singleton map.static class
A synchronized wrapper class for maps.static class
An unmodifiable wrapper class for maps. -
Field Summary
Modifier and TypeFieldDescriptionstatic final Object2ReferenceMaps.EmptyMap
An empty type-specific map (immutable). -
Method Summary
Modifier and TypeMethodDescriptionstatic <K,
V> Object2ReferenceMap <K, V> emptyMap()
Returns an empty map (immutable).static <K,
V> void fastForEach
(Object2ReferenceMap<K, V> map, Consumer<? super Object2ReferenceMap.Entry<K, V>> consumer) static <K,
V> ObjectIterable <Object2ReferenceMap.Entry<K, V>> fastIterable
(Object2ReferenceMap<K, V> map) static <K,
V> ObjectIterator <Object2ReferenceMap.Entry<K, V>> fastIterator
(Object2ReferenceMap<K, V> map) static <K,
V> Object2ReferenceMap <K, V> singleton
(K key, V value) Returns a type-specific immutable map containing only the specified pair.static <K,
V> Object2ReferenceMap <K, V> synchronize
(Object2ReferenceMap<K, V> m) Returns a synchronized type-specific map backed by the given type-specific map.static <K,
V> Object2ReferenceMap <K, V> synchronize
(Object2ReferenceMap<K, V> m, Object sync) Returns a synchronized type-specific map backed by the given type-specific map, using an assigned object to synchronize.static <K,
V> Object2ReferenceMap <K, V> unmodifiable
(Object2ReferenceMap<? extends K, ? extends V> m) Returns an unmodifiable type-specific map backed by the given type-specific map.
-
Field Details
-
EMPTY_MAP
An empty type-specific map (immutable). It is serializable and cloneable.
-
-
Method Details
-
fastIterator
public static <K,V> ObjectIterator<Object2ReferenceMap.Entry<K,V>> fastIterator(Object2ReferenceMap<K, V> map) - Parameters:
map
- a map from which we will try to extract a (fast) iterator on the entry set.- Returns:
- an iterator on the entry set of the given map that will be fast, if possible.
- Since:
- 8.0.0
-
fastForEach
public static <K,V> void fastForEach(Object2ReferenceMap<K, V> map, Consumer<? super Object2ReferenceMap.Entry<K, V>> consumer) - Parameters:
map
- a map on which we will try to iterate quickly.consumer
- the consumer that will be passed toObject2ReferenceMap.FastEntrySet.fastForEach(Consumer)
, if possible, or toIterable.forEach(Consumer)
.- Since:
- 8.1.0
-
fastIterable
public static <K,V> ObjectIterable<Object2ReferenceMap.Entry<K,V>> fastIterable(Object2ReferenceMap<K, V> map) Returns an iterable yielding an iterator that will be fast, if possible, on the entry set of the providedmap
.- Parameters:
map
- a map from which we will try to extract an iterable yielding a (fast) iterator on the entry set.- Returns:
- an iterable yielding an iterator on the entry set of the given map that will be fast, if possible.
- Since:
- 8.0.0
-
emptyMap
Returns an empty map (immutable). It is serializable and cloneable.This method provides a typesafe access to
EMPTY_MAP
.- Returns:
- an empty map (immutable).
-
singleton
Returns a type-specific immutable map containing only the specified pair. The returned map is serializable and cloneable.Note that albeit the returned map is immutable, its default return value may be changed.
- Parameters:
key
- the only key of the returned map.value
- the only value of the returned map.- Returns:
- a type-specific immutable map containing just the pair
<key,value>
.
-
synchronize
Returns a synchronized type-specific map backed by the given type-specific map.- Parameters:
m
- the map to be wrapped in a synchronized map.- Returns:
- a synchronized view of the specified map.
- See Also:
-
synchronize
Returns a synchronized type-specific map backed by the given type-specific map, using an assigned object to synchronize.- Parameters:
m
- the map to be wrapped in a synchronized map.sync
- an object that will be used to synchronize the access to the map.- Returns:
- a synchronized view of the specified map.
- See Also:
-
unmodifiable
public static <K,V> Object2ReferenceMap<K,V> unmodifiable(Object2ReferenceMap<? extends K, ? extends V> m) Returns an unmodifiable type-specific map backed by the given type-specific map.- Parameters:
m
- the map to be wrapped in an unmodifiable map.- Returns:
- an unmodifiable view of the specified map.
- See Also:
-