Function<java.lang.Short,V>
, java.util.function.Function<java.lang.Short,V>
, java.util.function.IntFunction<V>
Short2ReferenceMap<V>
, Short2ReferenceSortedMap<V>
AbstractShort2ReferenceFunction
, AbstractShort2ReferenceMap
, AbstractShort2ReferenceSortedMap
, Short2ReferenceArrayMap
, Short2ReferenceAVLTreeMap
, Short2ReferenceFunctions.EmptyFunction
, Short2ReferenceFunctions.PrimitiveFunction
, Short2ReferenceFunctions.Singleton
, Short2ReferenceFunctions.SynchronizedFunction
, Short2ReferenceFunctions.UnmodifiableFunction
, Short2ReferenceLinkedOpenHashMap
, Short2ReferenceMaps.EmptyMap
, Short2ReferenceMaps.Singleton
, Short2ReferenceMaps.SynchronizedMap
, Short2ReferenceMaps.UnmodifiableMap
, Short2ReferenceOpenCustomHashMap
, Short2ReferenceOpenHashMap
, Short2ReferenceRBTreeMap
, Short2ReferenceSortedMaps.EmptySortedMap
, Short2ReferenceSortedMaps.Singleton
, Short2ReferenceSortedMaps.SynchronizedSortedMap
, Short2ReferenceSortedMaps.UnmodifiableSortedMap
@FunctionalInterface public interface Short2ReferenceFunction<V> extends Function<java.lang.Short,V>, java.util.function.IntFunction<V>
Function
; provides some additional methods that use
polymorphism to avoid (un)boxing.
Type-specific versions of get()
, put()
and remove()
cannot rely on null
to denote absence of a key. Rather, they return a
default return value, which is set to
0/false at creation, but can be changed using the
defaultReturnValue()
method.
For uniformity reasons, even functions returning objects implement the
default return value (of course, in this case the default return value is
initialized to null
).
The default implementation of optional operations just throw an
UnsupportedOperationException
, except for the type-specific
containsKey()
, which return true. Generic versions of accessors delegate to
the corresponding type-specific counterparts following the interface rules.
Warning: to fall in line as much as possible with the
standard map interface, it is required that
standard versions of get()
, put()
and remove()
for
maps with primitive-type keys or values return null
to denote
missing keys rather than wrap the default return value in an object. In
case both keys and values are reference types, the default return value must
be returned instead, thus violating the standard
map interface when the default return value is not null
.
Function
Modifier and Type | Method | Description |
---|---|---|
default V |
apply(int operand) |
Deprecated.
Please use primitive types which don't have to be widened as
keys.
|
default boolean |
containsKey(short key) |
Returns true if this function contains a mapping for the specified key.
|
default boolean |
containsKey(java.lang.Object key) |
Deprecated.
Please use the corresponding type-specific method instead.
|
default V |
defaultReturnValue() |
Gets the default return value.
|
default void |
defaultReturnValue(V rv) |
Sets the default return value (optional operation).
|
V |
get(short key) |
Returns the value to which the given key is mapped.
|
default V |
get(java.lang.Object key) |
Deprecated.
Please use the corresponding type-specific method instead.
|
default V |
put(short key,
V value) |
Adds a pair to the map (optional operation).
|
default V |
put(java.lang.Short key,
V value) |
Deprecated.
Please use the corresponding type-specific method instead.
|
default V |
remove(short key) |
Removes the mapping with the given key (optional operation).
|
default V |
remove(java.lang.Object key) |
Deprecated.
Please use the corresponding type-specific method instead.
|
@Deprecated default V apply(int operand)
In this default implementation, the key gets narrowed down to the actual key
type, throwing an exception if the given key can't be represented in the
restricted domain. This is done for interoperability with the Java 8 function
environment. Its use is discouraged, as unexpected errors can occur. Instead,
the corresponding classes should be used (e.g.,
Int2IntFunction
instead of
Short2IntFunction
).
apply
in interface java.util.function.IntFunction<V>
java.lang.IllegalArgumentException
- If the given operand is not an element of the key domain.default V put(short key, V value)
key
- the key.value
- the value.Function.put(Object,Object)
V get(short key)
key
- the key.Function.get(Object)
default V remove(short key)
key
- the key.Function.remove(Object)
@Deprecated default V put(java.lang.Short key, V value)
@Deprecated default V get(java.lang.Object key)
@Deprecated default V remove(java.lang.Object key)
default boolean containsKey(short key)
Note that for some kind of functions (e.g., hashes) this method will always return true. In particular, this default implementation always returns true.
key
- the key.key
.Function.containsKey(Object)
@Deprecated default boolean containsKey(java.lang.Object key)
Note that for some kind of functions (e.g., hashes) this method will always return true. This default implementation, in particular, always return true.
containsKey
in interface Function<java.lang.Short,V>
key
- the key.key
.Map.containsKey(Object)
default void defaultReturnValue(V rv)
get()
,
put()
and remove()
to denote that the map does not contain
the specified key. It must be 0/false
/null
by default.rv
- the new default return value.defaultReturnValue()
default V defaultReturnValue()
This default implementation just return the default null value of the type
(null
for objects, 0 for scalars, false for Booleans).