Package com.helger.commons.functional
Interface IFunction<T,R>
-
- Type Parameters:
T- the type of the input to the functionR- the type of the result of the function
- All Superinterfaces:
Function<T,R>,Serializable
- All Known Subinterfaces:
IAggregator<SRCTYPE,DSTTYPE>,ISplitter<SRCTYPE,DSTTYPE>,ITypeConverter<SRC,DST>,ITypeConverterRule<SRC,DST>
- All Known Implementing Classes:
AbstractFormatterString,AbstractTypeConverterRule,FormatterMinLengthAddLeading,FormatterMinLengthAddTrailing,FormatterStringPrefixAndSuffix,FormatterStringSkipPrefixAndSuffix,TypeConverterRuleAnySourceFixedDestination,TypeConverterRuleAssignableSourceFixedDestination,TypeConverterRuleFixedSourceAnyDestination,TypeConverterRuleFixedSourceAssignableDestination
- 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 IFunction<T,R> extends Function<T,R>, Serializable
Represents a serializable function that accepts one argument and produces a result.This is a functional interface whose functional method is
Function.apply(Object).- Since:
- 8.6.0
-
-
Method Summary
All Methods Static Methods Instance Methods Default Methods Modifier and Type Method Description default <V> IFunction<T,V>andThen(Function<? super R,? extends V> after)Returns a composed function that first applies this function to its input, and then applies theafterfunction to the result.default <V> IFunction<V,R>compose(Function<? super V,? extends T> before)Returns a composed function that first applies thebeforefunction to its input, and then applies this function to the result.static <T> IFunction<T,T>identity()Returns a function that always returns its input argument.
-
-
-
Method Detail
-
compose
@Nonnull default <V> IFunction<V,R> compose(@Nonnull Function<? super V,? extends T> before)
Returns a composed function that first applies thebeforefunction to its input, and then applies this function to the result. If evaluation of either function throws an exception, it is relayed to the caller of the composed function.- Specified by:
composein interfaceFunction<T,R>- Type Parameters:
V- the type of input to thebeforefunction, and to the composed function- Parameters:
before- the function to apply before this function is applied- Returns:
- a composed function that first applies the
beforefunction and then applies this function - Throws:
NullPointerException- if before is null- See Also:
andThen(Function)
-
andThen
@Nonnull default <V> IFunction<T,V> andThen(@Nonnull Function<? super R,? extends V> after)
Returns a composed function that first applies this function to its input, and then applies theafterfunction to the result. If evaluation of either function throws an exception, it is relayed to the caller of the composed function.- Specified by:
andThenin interfaceFunction<T,R>- Type Parameters:
V- the type of output of theafterfunction, and of the composed function- Parameters:
after- the function to apply after this function is applied- Returns:
- a composed function that first applies this function and then
applies the
afterfunction - Throws:
NullPointerException- if after is null- See Also:
compose(Function)
-
-