Interface Function<F extends @Nullable java.lang.Object,T extends @Nullable java.lang.Object>
- 
- All Known Subinterfaces:
- LoadingCache<K,V>
 - All Known Implementing Classes:
- AbstractLoadingCache,- Converter,- ForwardingLoadingCache,- ForwardingLoadingCache.SimpleForwardingLoadingCache
 
 @GwtCompatible public interface Function<F extends @Nullable java.lang.Object,T extends @Nullable java.lang.Object> Determines an output value based on an input value; a pre-Java-8 version ofjava.util.function.Function.The Functionsclass provides common functions and related utilities.See the Guava User Guide article on the use of Function.For Java 8+ usersThis interface is now a legacy type. Use java.util.function.Function(or the appropriate primitive specialization such asToIntFunction) instead whenever possible. Otherwise, at least reduce explicit dependencies on this type by using lambda expressions or method references instead of classes, leaving your code easier to migrate in the future.To use an existing function (say, named function) in a context where the other type of function is expected, use the method referencefunction::apply. A future version ofcom.google.common.base.Functionwill be made to extendjava.util.function.Function, making conversion code necessary only in one direction. At that time, this interface will be officially discouraged.- Since:
- 2.0
- Author:
- Kevin Bourrillion
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Modifier and Type Method Description Tapply(F input)Returns the result of applying this function toinput.booleanequals(java.lang.Object object)May returntrueifobjectis aFunctionthat behaves identically to this function.
 
- 
- 
- 
Method Detail- 
applyT apply(F input) Returns the result of applying this function toinput. This method is generally expected, but not absolutely required, to have the following properties:- Its execution does not cause any observable side effects.
- The computation is consistent with equals; that is, Objects.equal(a, b)implies thatObjects.equal(function.apply(a), function.apply(b)).
 - Throws:
- java.lang.NullPointerException- if- inputis null and this function does not accept null arguments
 
 - 
equalsboolean equals(@CheckForNull java.lang.Object object) May returntrueifobjectis aFunctionthat behaves identically to this function.Warning: do not depend on the behavior of this method. Historically, Functioninstances in this library have implemented this method to recognize certain cases where distinctFunctioninstances would in fact behave identically. However, as code migrates tojava.util.function, that behavior will disappear. It is best not to depend on it.- Overrides:
- equalsin class- java.lang.Object
 
 
- 
 
-