Interface Predicate<T extends @Nullable java.lang.Object>
-
- All Superinterfaces:
java.util.function.Predicate<T>
- All Known Implementing Classes:
BloomFilter
,CharMatcher
,Range
- Functional Interface:
- This is a functional interface and can therefore be used as the assignment target for a lambda expression or method reference.
@FunctionalInterface @GwtCompatible public interface Predicate<T extends @Nullable java.lang.Object> extends java.util.function.Predicate<T>
Legacy version ofjava.util.function.Predicate
. Determines a true or false value for a given input.As this interface extends
java.util.function.Predicate
, an instance of this type may be used as aPredicate
directly. To use ajava.util.function.Predicate
where acom.google.common.base.Predicate
is expected, use the method referencepredicate::test
.This interface is now a legacy type. Use
java.util.function.Predicate
(or the appropriate primitive specialization such asIntPredicate
) 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.The
Predicates
class provides common predicates and related utilities.See the Guava User Guide article on the use of
Predicate
.- Since:
- 2.0
- Author:
- Kevin Bourrillion
-
-
Method Summary
All Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description boolean
apply(T input)
Returns the result of applying this predicate toinput
(Java 8 users, see notes in the class documentation above).boolean
equals(java.lang.Object object)
Indicates whether another object is equal to this predicate.default boolean
test(T input)
-
-
-
Method Detail
-
apply
boolean apply(T input)
Returns the result of applying this predicate toinput
(Java 8 users, see notes in the class documentation above). 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 thatpredicate.apply(a) == predicate.apply(b))
.
- Throws:
java.lang.NullPointerException
- ifinput
is null and this predicate does not accept null arguments
-
equals
boolean equals(@CheckForNull java.lang.Object object)
Indicates whether another object is equal to this predicate.Most implementations will have no reason to override the behavior of
Object.equals(java.lang.Object)
. However, an implementation may also choose to returntrue
wheneverobject
is aPredicate
that it considers interchangeable with this one. "Interchangeable" typically means thatthis.apply(t) == that.apply(t)
for allt
of typeT
). Note that afalse
result from this method does not imply that the predicates are known not to be interchangeable.- Overrides:
equals
in classjava.lang.Object
-
-