Interface TypeVariable<D extendsGenericDeclaration>
- Type Parameters:
D- the type of generic declaration that declared theunderlying type variable.
- All Superinterfaces:
AnnotatedElement,Type
TypeVariable is the common superinterface for type variables of kinds.A type variable is created the first time it is needed by a reflectivemethod, as specified in this package. If a type variable t is referencedby a type (i.e, class, interface or annotation type) T, and T is declaredby the nth enclosing class of T (see JLS8.1.2), then the creation of trequires the resolution (see JVMS5) of the ith enclosing class of T,for i = 0 to n, inclusive. Creating a type variable must not cause thecreation of its bounds. Repeated creation of a type variable has no effect.
Multiple objects may be instantiated at run-time torepresent a given type variable. Even though a type variable iscreated only once, this does not imply any requirement to cacheinstances representing the type variable. However, all instancesrepresenting a type variable must be equal() to each other.As a consequence, users of type variables must not rely on the identityof instances of classes implementing this interface.
- SeeJava Language Specification:
- 4.4 Type Variables
- Since:
- 1.5
Method Summary
Modifier and TypeMethodDescriptionReturns an array of AnnotatedType objects that represent the use oftypes to denote the upper bounds of the type parameter represented bythis TypeVariable.Type[]Returns an array ofTypeobjects representing theupper bound(s) of this type variable.Returns theGenericDeclarationobject representing thegeneric declaration declared for this type variable.getName()Returns the name of this type variable, as it occurs in the source code.Methods declared in interface AnnotatedElement
getAnnotation,getAnnotations,getAnnotationsByType,getDeclaredAnnotation,getDeclaredAnnotations,getDeclaredAnnotationsByType,isAnnotationPresentMethods declared in interface Type
getTypeName
Method Details
getBounds
Type[] getBounds()Returns an array ofTypeobjects representing theupper bound(s) of this type variable. If no upper bound isexplicitly declared, the upper bound isObject.For each upper bound B:
- if B is a parameterizedtype or a type variable, it is created, (see
ParameterizedTypefor thedetails of the creation process for parameterized types). - Otherwise, B is resolved.
- Returns:
- an array of
Types representing the upper bound(s) of this type variable - Throws:
TypeNotPresentException- if any of the bounds refers to a non-existent type declarationMalformedParameterizedTypeException- if any of the bounds refer to a parameterized type that cannot be instantiated for any reason
- if B is a parameterizedtype or a type variable, it is created, (see
getGenericDeclaration
D getGenericDeclaration()Returns theGenericDeclarationobject representing thegeneric declaration declared for this type variable.- Returns:
- the generic declaration declared for this type variable.
- Since:
- 1.5
getName
String getName()Returns the name of this type variable, as it occurs in the source code.- Returns:
- the name of this type variable, as it appears in the source code
getAnnotatedBounds
AnnotatedType[] getAnnotatedBounds()Returns an array of AnnotatedType objects that represent the use oftypes to denote the upper bounds of the type parameter represented bythis TypeVariable. The order of the objects in the array corresponds tothe order of the bounds in the declaration of the type parameter. Note thatif no upper bound is explicitly declared, the upper bound is unannotatedObject.- Returns:
- an array of objects representing the upper bound(s) of the type variable
- Since:
- 1.8