Class Key<T>
For example, Key.get(Service.class, Transactional.class)
will
match:
@Inject public void setService(@Transactional Service service) { ... }
Key
supports generic types via subclassing just like TypeLiteral
.
Keys do not differentiate between primitive types (int, char, etc.) and their corresponding wrapper types (Integer, Character, etc.). Primitive types will be replaced with their wrapper types when keys are created.
-
Constructor Summary
ModifierConstructorDescriptionprotected
Key()
Constructs a new key.protected
Key
(Annotation annotation) Constructs a new key.protected
Key
(Class<? extends Annotation> annotationType) Constructs a new key. -
Method Summary
Modifier and TypeMethodDescriptionfinal boolean
static <T> Key<T>
Gets a key for an injection type.static <T> Key<T>
get
(Class<T> type, Annotation annotation) Gets a key for an injection type and an annotation.static <T> Key<T>
get
(Class<T> type, Class<? extends Annotation> annotationType) Gets a key for an injection type and an annotation type.static Key<?>
Gets a key for an injection type.static Key<?>
get
(Type type, Annotation annotation) Gets a key for an injection type and an annotation.static Key<?>
get
(Type type, Class<? extends Annotation> annotationType) Gets a key for an injection type and an annotation type.static <T> Key<T>
get
(TypeLiteral<T> typeLiteral) Gets a key for an injection type.static <T> Key<T>
get
(TypeLiteral<T> typeLiteral, Annotation annotation) Gets a key for an injection type and an annotation.static <T> Key<T>
get
(TypeLiteral<T> typeLiteral, Class<? extends Annotation> annotationType) Gets a key for an injection type and an annotation type.final Annotation
Gets the annotation.final Class<? extends Annotation>
Gets the annotation type.final TypeLiteral<T>
Gets the key type.final int
hashCode()
final String
toString()
-
Constructor Details
-
Key
Constructs a new key. Derives the type from this class's type parameter.Clients create an empty anonymous subclass. Doing so embeds the type parameter in the anonymous class's type hierarchy so we can reconstitute it at runtime despite erasure.
Example usage for a binding of type
Foo
annotated with@Bar
:new Key<Foo>(Bar.class) {}
. -
Key
Constructs a new key. Derives the type from this class's type parameter.Clients create an empty anonymous subclass. Doing so embeds the type parameter in the anonymous class's type hierarchy so we can reconstitute it at runtime despite erasure.
Example usage for a binding of type
Foo
annotated with@Bar
:new Key<Foo>(new Bar()) {}
. -
Key
protected Key()Constructs a new key. Derives the type from this class's type parameter.Clients create an empty anonymous subclass. Doing so embeds the type parameter in the anonymous class's type hierarchy so we can reconstitute it at runtime despite erasure.
Example usage for a binding of type
Foo
:new Key<Foo>() {}
.
-
-
Method Details
-
getTypeLiteral
Gets the key type. -
getAnnotationType
Gets the annotation type. -
getAnnotation
Gets the annotation. -
equals
-
hashCode
public final int hashCode() -
toString
-
get
Gets a key for an injection type. -
get
Gets a key for an injection type and an annotation type. -
get
Gets a key for an injection type and an annotation. -
get
Gets a key for an injection type. -
get
Gets a key for an injection type and an annotation type. -
get
Gets a key for an injection type and an annotation. -
get
Gets a key for an injection type. -
get
public static <T> Key<T> get(TypeLiteral<T> typeLiteral, Class<? extends Annotation> annotationType) Gets a key for an injection type and an annotation type. -
get
Gets a key for an injection type and an annotation.
-