Interface Byte2LongFunction
- All Superinterfaces:
Function<java.lang.Byte,java.lang.Long>,java.util.function.Function<java.lang.Byte,java.lang.Long>,java.util.function.IntToLongFunction
- Functional Interface:
- This is a functional interface and can therefore be used as the assignment target for a lambda expression or method reference.
@FunctionalInterface public interface Byte2LongFunction extends Function<java.lang.Byte,java.lang.Long>, java.util.function.IntToLongFunction
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.
- See Also:
Function
-
Method Summary
Modifier and Type Method Description default <T> java.util.function.Function<java.lang.Byte,T>andThen(java.util.function.Function<? super java.lang.Long,? extends T> after)Deprecated.Please use the corresponding type-specific method instead.default Byte2ByteFunctionandThenByte(Long2ByteFunction after)default Byte2CharFunctionandThenChar(Long2CharFunction after)default Byte2DoubleFunctionandThenDouble(Long2DoubleFunction after)default Byte2FloatFunctionandThenFloat(Long2FloatFunction after)default Byte2IntFunctionandThenInt(Long2IntFunction after)default Byte2LongFunctionandThenLong(Long2LongFunction after)default <T> Byte2ObjectFunction<T>andThenObject(Long2ObjectFunction<? extends T> after)default <T> Byte2ReferenceFunction<T>andThenReference(Long2ReferenceFunction<? extends T> after)default Byte2ShortFunctionandThenShort(Long2ShortFunction after)default longapplyAsLong(int operand)Deprecated.Please use primitive types which do not have to be widened as keys.default <T> java.util.function.Function<T,java.lang.Long>compose(java.util.function.Function<? super T,? extends java.lang.Byte> before)Deprecated.Please use the corresponding type-specific method instead.default Byte2LongFunctioncomposeByte(Byte2ByteFunction before)default Char2LongFunctioncomposeChar(Char2ByteFunction before)default Double2LongFunctioncomposeDouble(Double2ByteFunction before)default Float2LongFunctioncomposeFloat(Float2ByteFunction before)default Int2LongFunctioncomposeInt(Int2ByteFunction before)default Long2LongFunctioncomposeLong(Long2ByteFunction before)default <T> Object2LongFunction<T>composeObject(Object2ByteFunction<? super T> before)default <T> Reference2LongFunction<T>composeReference(Reference2ByteFunction<? super T> before)default Short2LongFunctioncomposeShort(Short2ByteFunction before)default booleancontainsKey(byte key)Returns true if this function contains a mapping for the specified key.default booleancontainsKey(java.lang.Object key)Deprecated.Please use the corresponding type-specific method instead.default longdefaultReturnValue()Gets the default return value.default voiddefaultReturnValue(long rv)Sets the default return value (optional operation).longget(byte key)Returns the value to which the given key is mapped.default java.lang.Longget(java.lang.Object key)Deprecated.Please use the corresponding type-specific method instead.default longgetOrDefault(byte key, long defaultValue)Returns the value associated by this function to the specified key, or give the specified value if not present.default java.lang.LonggetOrDefault(java.lang.Object key, java.lang.Long defaultValue)Deprecated.Please use the corresponding type-specific method instead.default longput(byte key, long value)Adds a pair to the map (optional operation).default java.lang.Longput(java.lang.Byte key, java.lang.Long value)Deprecated.Please use the corresponding type-specific method instead.default longremove(byte key)Removes the mapping with the given key (optional operation).default java.lang.Longremove(java.lang.Object key)Deprecated.Please use the corresponding type-specific method instead.
-
Method Details
-
applyAsLong
@Deprecated default long applyAsLong(int operand)Deprecated.Please use primitive types which do not have to be widened as keys.- Specified by:
applyAsLongin interfacejava.util.function.IntToLongFunction- Throws:
java.lang.IllegalArgumentException- If the given operand is not an element of the key domain.- Since:
- 8.0.0
- Implementation Specification:
- This default implementation delegates to the type-specific
get()method after narrowing down the key to the actual key type, throwing an exception if the given key cannot be represented in the restricted domain. This is done for interoperability with the Java 8 function environment. The use of this method is discouraged, as unexpected errors can occur. Instead, the corresponding classes should be used (e.g.,Int2IntFunctioninstead ofShort2IntFunction).
-
put
default long put(byte key, long value)Adds a pair to the map (optional operation).- Parameters:
key- the key.value- the value.- Returns:
- the old value, or the default return value if no value was present for the given key.
- See Also:
Function.put(Object,Object)
-
get
long get(byte key)Returns the value to which the given key is mapped.- Parameters:
key- the key.- Returns:
- the corresponding value, or the default return value if no value was present for the given key.
- See Also:
Function.get(Object)
-
getOrDefault
default long getOrDefault(byte key, long defaultValue)Returns the value associated by this function to the specified key, or give the specified value if not present.- Parameters:
key- the key.defaultValue- the value to return if not present.- Returns:
- the corresponding value, or
defaultValueif no value was present for the given key. - Since:
- 8.5.0
- See Also:
Function.getOrDefault(Object, Object)
-
remove
default long remove(byte key)Removes the mapping with the given key (optional operation).- Parameters:
key- the key.- Returns:
- the old value, or the default return value if no value was present for the given key.
- See Also:
Function.remove(Object)
-
put
@Deprecated default java.lang.Long put(java.lang.Byte key, java.lang.Long value)Deprecated.Please use the corresponding type-specific method instead.Associates the specified value with the specified key in this function (optional operation). -
get
@Deprecated default java.lang.Long get(java.lang.Object key)Deprecated.Please use the corresponding type-specific method instead.Returns the value associated by this function to the specified key. -
getOrDefault
@Deprecated default java.lang.Long getOrDefault(java.lang.Object key, java.lang.Long defaultValue)Deprecated.Please use the corresponding type-specific method instead.Returns the value associated by this function to the specified key, or give the specified value if not present.- Specified by:
getOrDefaultin interfaceFunction<java.lang.Byte,java.lang.Long>- Parameters:
key- the key.defaultValue- the default value to return if not present.- Returns:
- the corresponding value, or
defaultValueif no value was present for the given key. - See Also:
Map.getOrDefault(Object, Object)
-
remove
@Deprecated default java.lang.Long remove(java.lang.Object key)Deprecated.Please use the corresponding type-specific method instead.Removes this key and the associated value from this function if it is present (optional operation). -
containsKey
default boolean containsKey(byte key)Returns true if this function contains a mapping for the specified 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.
- Parameters:
key- the key.- Returns:
- true if this function associates a value to
key. - See Also:
Function.containsKey(Object)
-
containsKey
@Deprecated default boolean containsKey(java.lang.Object key)Deprecated.Please use the corresponding type-specific method instead.Returns true if this function contains a mapping for the specified 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.
- Specified by:
containsKeyin interfaceFunction<java.lang.Byte,java.lang.Long>- Parameters:
key- the key.- Returns:
- true if this function associates a value to
key. - See Also:
Map.containsKey(Object)
-
defaultReturnValue
default void defaultReturnValue(long rv)Sets the default return value (optional operation). This value must be returned by type-specific versions ofget(),put()andremove()to denote that the map does not contain the specified key. It must be 0/false/nullby default.- Parameters:
rv- the new default return value.- See Also:
defaultReturnValue()
-
defaultReturnValue
default long defaultReturnValue()Gets the default return value.This default implementation just return the default null value of the type (
nullfor objects, 0 for scalars, false for Booleans).- Returns:
- the current default return value.
-
compose
@Deprecated default <T> java.util.function.Function<T,java.lang.Long> compose(java.util.function.Function<? super T,? extends java.lang.Byte> before)Deprecated.Please use the corresponding type-specific method instead.- Specified by:
composein interfacejava.util.function.Function<java.lang.Byte,java.lang.Long>
-
andThen
@Deprecated default <T> java.util.function.Function<java.lang.Byte,T> andThen(java.util.function.Function<? super java.lang.Long,? extends T> after)Deprecated.Please use the corresponding type-specific method instead.- Specified by:
andThenin interfacejava.util.function.Function<java.lang.Byte,java.lang.Long>
-
andThenByte
-
composeByte
-
andThenShort
-
composeShort
-
andThenInt
-
composeInt
-
andThenLong
-
composeLong
-
andThenChar
-
composeChar
-
andThenFloat
-
composeFloat
-
andThenDouble
-
composeDouble
-
andThenObject
-
composeObject
-
andThenReference
-
composeReference
-