先造一个测试用例:
public class TransactionServiceTest {
@Resource
private IQrcodeAdScheduleService qrcodeAdScheduleService;
}
而后启动Spring Boot能够看到上面的调用栈信息:
图1
由上图可知,在创立完bean实例后,通过applyMergedBeanDefinitionPostProcessors()批改beanDefinition构造(针对这种场景能够了解为解析@Resource对应的bean信息)
protected void applyMergedBeanDefinitionPostProcessors(RootBeanDefinition mbd, Class<?> beanType, String beanName) {
for (BeanPostProcessor bp : getBeanPostProcessors()) {
if (bp instanceof MergedBeanDefinitionPostProcessor) {
MergedBeanDefinitionPostProcessor bdp = (MergedBeanDefinitionPostProcessor) bp;
//执行CommonAnnotationBeanPostProcessor类postProcessMergedBeanDefinition()
bdp.postProcessMergedBeanDefinition(mbd, beanType, beanName);
}
}
}
图2
有图2可知,解决@Resource的PostProcessor是“CommonAnnotationBeanPostProcessor”,而后看一下CommonAnnotationBeanPostProcessor的局部细节:
private InjectionMetadata buildResourceMetadata(final Class<?> clazz) {
LinkedList<InjectionMetadata.InjectedElement> elements = new LinkedList<>();
Class<?> targetClass = clazz;
do {
final LinkedList<InjectionMetadata.InjectedElement> currElements =
new LinkedList<>();
ReflectionUtils.doWithLocalFields(targetClass, field -> {
if (webServiceRefClass != null && field.isAnnotationPresent(webServiceRefClass)) {
if (Modifier.isStatic(field.getModifiers())) {
throw new IllegalStateException("@WebServiceRef annotation is not supported on static fields");
}
currElements.add(new WebServiceRefElement(field, field, null));
}
else if (ejbRefClass != null && field.isAnnotationPresent(ejbRefClass)) {
if (Modifier.isStatic(field.getModifiers())) {
throw new IllegalStateException("@EJB annotation is not supported on static fields");
}
currElements.add(new EjbRefElement(field, field, null));
}
//解析@Resource.class
else if (field.isAnnotationPresent(Resource.class)) {
if (Modifier.isStatic(field.getModifiers())) {
throw new IllegalStateException("@Resource annotation is not supported on static fields");
}
if (!ignoredResourceTypes.contains(field.getType().getName())) {
currElements.add(new ResourceElement(field, field, null));
}
}
});
}
下面的代码块呈现了期待已久的“Resource.class”关键字,咱们就释怀了。咱们再回顾一下,
其流程是这样的:在AbstractAutowireCapableBeanFactory.populateBean()->ibp.postProcessPropertyValue()->CommonAnnotationBeanPostProcessor.postProcessPropertyValue()去实例化@Resource作用的bean;
除了和解决@Autowired不是一个PostProcessor(解决@AutoWireds是用这个“AutowiredAnnotationBeanPostProcessor”PostProcessor)其余解决流程和@Autowired的解决流程一毛一样啊!
发表回复