Interface Function1<T1,R>
- Type Parameters:
T1- argument 1 of the functionR- return type of the function
- All Superinterfaces:
Function<T1,R>, Serializable
- All Known Subinterfaces:
API.Match.Case<T,R>, API.Match.Pattern<T, R>, BitSet<T>, IndexedSeq<T>, LinearSeq<T>, List<T>, Map<K, V>, Multimap<K, V>, PartialFunction<T, R>, Seq<T>, Set<T>, SortedMap<K, V>, SortedMultimap<K, V>, SortedSet<T>, Stream<T>
- All Known Implementing Classes:
AbstractMultimap, API.Match.Case0, API.Match.Case1, API.Match.Case2, API.Match.Case3, API.Match.Case4, API.Match.Case5, API.Match.Case6, API.Match.Case7, API.Match.Case8, API.Match.Pattern0, API.Match.Pattern1, API.Match.Pattern2, API.Match.Pattern3, API.Match.Pattern4, API.Match.Pattern5, API.Match.Pattern6, API.Match.Pattern7, API.Match.Pattern8, Array, BitSetModule.AbstractBitSet, BitSetModule.BitSet1, BitSetModule.BitSet2, BitSetModule.BitSetN, CharSeq, HashMap, HashMultimap, HashSet, LinkedHashMap, LinkedHashMultimap, LinkedHashSet, List.Cons, List.Nil, Queue, Stream.Cons, Stream.Empty, StreamModule.AppendElements, StreamModule.ConsImpl, TreeMap, TreeMultimap, TreeSet, Vector
- Functional Interface:
- This is a functional interface and can therefore be used as the assignment target for a lambda expression or method reference.
Represents a function with one argument.
-
Field Summary
Fields -
Method Summary
Modifier and TypeMethodDescriptionReturns a composed function that first applies this Function1 to the given argument and then applies Functionafterto the result.Applies this function to one argument and returns the result.default intarity()Returns the number of function arguments.Returns a composed function that first applies the Functionbeforethe given argument and then applies this Function1 to the result.static <T1,R> Function1 <T1, R> constant(R value) Returns a function that always returns the constant value that you give in parameter.curried()Returns a curried version of this function.static <T> Function1<T, T> identity()Returns the identity Function1, i.e.default booleanChecks if this function is memoizing (= caching) computed values.Lifts the givenpartialFunctioninto a total function that returns anOptionresult.Lifts the givenpartialFunctioninto a total function that returns anTryresult.memoized()Returns a memoizing version of this function, which computes the return value for given arguments only one time.static <T1,R> Function1 <T1, R> Narrows the givenFunction1<? super T1, ? extends R>toFunction1<T1, R>static <T1,R> Function1 <T1, R> default PartialFunction<T1, R> reversed()Returns a reversed version of this function.tupled()Returns a tupled version of this function.
-
Field Details
-
serialVersionUID
-
-
Method Details
-
constant
Returns a function that always returns the constant value that you give in parameter.- Type Parameters:
T1- generic parameter type 1 of the resulting functionR- the result type- Parameters:
value- the value to be returned- Returns:
- a function always returning the given value
-
of
Creates aFunction1based on Examples (w.l.o.g. referring to Function1):// using a lambda expression Function1<Integer, Integer> add1 = Function1.of(i -> i + 1); // using a method reference (, e.g. Integer method(Integer i) { return i + 1; }) Function1<Integer, Integer> add2 = Function1.of(this::method); // using a lambda reference Function1<Integer, Integer> add3 = Function1.of(add1::apply);Caution: Reflection loses type information of lambda references.
// type of a lambda expression Type<?, ?> type1 = add1.getType(); // (Integer) -> Integer // type of a method reference Type<?, ?> type2 = add2.getType(); // (Integer) -> Integer // type of a lambda reference Type<?, ?> type3 = add3.getType(); // (Object) -> Object- Type Parameters:
T1- 1st argumentR- return type- Parameters:
methodReference- (typically) a method reference, e.g.Type::method- Returns:
- a
Function1
-
lift
Lifts the givenpartialFunctioninto a total function that returns anOptionresult.- Type Parameters:
T1- 1st argumentR- return type- Parameters:
partialFunction- a function that is not defined for all values of the domain (e.g. by throwing)- Returns:
- a function that applies arguments to the given
partialFunctionand returnsSome(result)if the function is defined for the given arguments, andNoneotherwise.
-
liftTry
Lifts the givenpartialFunctioninto a total function that returns anTryresult.- Type Parameters:
T1- 1st argumentR- return type- Parameters:
partialFunction- a function that is not defined for all values of the domain (e.g. by throwing)- Returns:
- a function that applies arguments to the given
partialFunctionand returnsSuccess(result)if the function is defined for the given arguments, andFailure(throwable)otherwise.
-
narrow
-
identity
Returns the identity Function1, i.e. the function that returns its input.- Type Parameters:
T- argument type (and return type) of the identity function- Returns:
- the identity Function1
-
apply
-
arity
default int arity()Returns the number of function arguments.- Returns:
- an int value >= 0
- See Also:
-
curried
-
tupled
-
reversed
-
memoized
Returns a memoizing version of this function, which computes the return value for given arguments only one time. On subsequent calls given the same arguments the memoized value is returned.Please note that memoizing functions do not permit
nullas single argument or return value.- Returns:
- a memoizing function equivalent to this.
-
isMemoized
default boolean isMemoized()Checks if this function is memoizing (= caching) computed values.- Returns:
- true, if this function is memoizing, false otherwise
-
partial
- Parameters:
isDefinedAt- a predicate that states if an element is in the domain of the returnedPartialFunction.- Returns:
- a new
PartialFunctionthat has the same behavior like this function but is defined only for those elements that make it through the givenPredicate - Throws:
NullPointerException- ifisDefinedAtis null
-
andThen
Returns a composed function that first applies this Function1 to the given argument and then applies Functionafterto the result.- Specified by:
andThenin interfaceFunction<T1,R> - Type Parameters:
V- return type of after- Parameters:
after- the function applied after this- Returns:
- a function composed of this and after
- Throws:
NullPointerException- if after is null
-
compose
Returns a composed function that first applies the Functionbeforethe given argument and then applies this Function1 to the result.- Specified by:
composein interfaceFunction<T1,R> - Type Parameters:
V- argument type of before- Parameters:
before- the function applied before this- Returns:
- a function composed of before and this
- Throws:
NullPointerException- if before is null
-