public class DependencyDescriptor extends InjectionPoint implements Serializable
field, methodParameter| Constructor and Description | 
|---|
| DependencyDescriptor(DependencyDescriptor original)Copy constructor. | 
| DependencyDescriptor(Field field,
                    boolean required)Create a new descriptor for a field. | 
| DependencyDescriptor(Field field,
                    boolean required,
                    boolean eager)Create a new descriptor for a field. | 
| DependencyDescriptor(org.springframework.core.MethodParameter methodParameter,
                    boolean required)Create a new descriptor for a method or constructor parameter. | 
| DependencyDescriptor(org.springframework.core.MethodParameter methodParameter,
                    boolean required,
                    boolean eager)Create a new descriptor for a method or constructor parameter. | 
| Modifier and Type | Method and Description | 
|---|---|
| boolean | equals(Object other) | 
| boolean | fallbackMatchAllowed()Return whether a fallback match is allowed. | 
| DependencyDescriptor | forFallbackMatch()Return a variant of this descriptor that is intended for a fallback match. | 
| Class<?> | getCollectionType()Deprecated. 
 as of 4.3.6, in favor of direct  ResolvableTypeusage | 
| String | getDependencyName()Determine the name of the wrapped parameter/field. | 
| Class<?> | getDependencyType()Determine the declared (non-generic) type of the wrapped parameter/field. | 
| Class<?> | getMapKeyType()Deprecated. 
 as of 4.3.6, in favor of direct  ResolvableTypeusage | 
| Class<?> | getMapValueType()Deprecated. 
 as of 4.3.6, in favor of direct  ResolvableTypeusage | 
| org.springframework.core.ResolvableType | getResolvableType()Build a ResolvableType object for the wrapped parameter/field. | 
| void | increaseNestingLevel()Increase this descriptor's nesting level. | 
| void | initParameterNameDiscovery(org.springframework.core.ParameterNameDiscoverer parameterNameDiscoverer)Initialize parameter name discovery for the underlying method parameter, if any. | 
| boolean | isEager()Return whether this dependency is 'eager' in the sense of
 eagerly resolving potential target beans for type matching. | 
| boolean | isRequired()Return whether this dependency is required. | 
| Object | resolveCandidate(String beanName,
                Class<?> requiredType,
                BeanFactory beanFactory)Resolve the specified bean name, as a candidate result of the matching
 algorithm for this dependency, to a bean instance from the given factory. | 
| Object | resolveNotUnique(Class<?> type,
                Map<String,Object> matchingBeans)Resolve the specified not-unique scenario: by default,
 throwing a  NoUniqueBeanDefinitionException. | 
| Object | resolveShortcut(BeanFactory beanFactory)Resolve a shortcut for this dependency against the given factory, for example
 taking some pre-resolved information into account. | 
| void | setContainingClass(Class<?> containingClass)Optionally set the concrete class that contains this dependency. | 
getAnnotatedElement, getAnnotation, getAnnotations, getDeclaredType, getField, getMember, getMethodParameter, hashCode, toStringpublic DependencyDescriptor(org.springframework.core.MethodParameter methodParameter,
                            boolean required)
methodParameter - the MethodParameter to wraprequired - whether the dependency is requiredpublic DependencyDescriptor(org.springframework.core.MethodParameter methodParameter,
                            boolean required,
                            boolean eager)
methodParameter - the MethodParameter to wraprequired - whether the dependency is requiredeager - whether this dependency is 'eager' in the sense of
 eagerly resolving potential target beans for type matchingpublic DependencyDescriptor(Field field, boolean required)
field - the field to wraprequired - whether the dependency is requiredpublic DependencyDescriptor(Field field, boolean required, boolean eager)
field - the field to wraprequired - whether the dependency is requiredeager - whether this dependency is 'eager' in the sense of
 eagerly resolving potential target beans for type matchingpublic DependencyDescriptor(DependencyDescriptor original)
original - the original descriptor to create a copy frompublic boolean isRequired()
public boolean isEager()
public Object resolveNotUnique(Class<?> type, Map<String,Object> matchingBeans) throws BeansException
NoUniqueBeanDefinitionException.
 Subclasses may override this to select one of the instances or
 to opt out with no result at all through returning null.
type - the requested bean typematchingBeans - a map of bean names and corresponding bean
 instances which have been pre-selected for the given type
 (qualifiers etc already applied)null for noneBeansException - in case of the not-unique scenario being fatalpublic Object resolveShortcut(BeanFactory beanFactory) throws BeansException
The resolution algorithm will first attempt to resolve a shortcut through this
 method before going into the regular type matching algorithm across all beans.
 Subclasses may override this method to improve resolution performance based on
 pre-cached information while still receiving InjectionPoint exposure etc.
beanFactory - the associated factorynull if noneBeansException - if the shortcut could not be obtainedpublic Object resolveCandidate(String beanName, Class<?> requiredType, BeanFactory beanFactory) throws BeansException
The default implementation calls BeanFactory.getBean(String).
 Subclasses may provide additional arguments or other customizations.
beanName - the bean name, as a candidate result for this dependencyrequiredType - the expected type of the bean (as an assertion)beanFactory - the associated factorynull)BeansException - if the bean could not be obtainedBeanFactory.getBean(String)public void increaseNestingLevel()
MethodParameter.increaseNestingLevel()public void setContainingClass(Class<?> containingClass)
public org.springframework.core.ResolvableType getResolvableType()
public boolean fallbackMatchAllowed()
This is false by default but may be overridden to return true in order
 to suggest to a AutowireCandidateResolver
 that a fallback match is acceptable as well.
public DependencyDescriptor forFallbackMatch()
fallbackMatchAllowed()public void initParameterNameDiscovery(org.springframework.core.ParameterNameDiscoverer parameterNameDiscoverer)
This method does not actually try to retrieve the parameter name at
 this point; it just allows discovery to happen when the application calls
 getDependencyName() (if ever).
public String getDependencyName()
null)public Class<?> getDependencyType()
null)@Deprecated public Class<?> getCollectionType()
ResolvableType usagenull if none@Deprecated public Class<?> getMapKeyType()
ResolvableType usagenull if none@Deprecated public Class<?> getMapValueType()
ResolvableType usagenull if nonepublic boolean equals(Object other)
equals in class InjectionPoint