内容简介:使用实现了
@Configuration
注解指示一个类声明一个或多个@Bean方法, 并且可以由Spring容器处理, 以在运行时为这些bean生成bean定义和服务请求.
使用 ConfigurationClassParser
来对 @Configuration
标注的类进行解析, 封装成 ConfigurationClass
实例. 具体的实现通过 ConfigurationClassPostProcessor
来实现的.
ConfigurationClassPostProcessor
实现了 BeanDefinitionRegistryPostProcessor
接口, 间接实现了 BeanFactorPostProcessor
接口.
-
#postProcessBeanDefinitionRegistry(): 注册所有ConfigurationClass中的BeanDefinition, 包括@Bean注解的方法,@ImporResource引入的资源中定义的bean, 和@Import注解引入的ImportBeanDefinitionRegistrar中注册的BeanDefinition -
#postProcessBeanFactory(): 在运行时以通过cglig增强的类来替换ConfigurationClass, 为服务bean请求做准备. 增强的实现是通过ConfigurationClassEnhancer完成的.
插入一点, ConfigurationClassEnhancer
实现了直接使用bean注册方法来获取bean的操作, 提供了一个 BeanMethodInterceptor
的内部类来实行.
@Configuration
public class Config {
@Bean
public A a() {
...
return a;
}
@Bean
public B b() {
b.setA(a());
...
return b;
}
}
Full ConfigurationClass VS Lite ConfigurationClass
先说区别: full的 ConfigurationClass
会使用CGLIB进行增强.
查看类 ConfigurationClassUtils
, 其中有两个方法 #isFullConfigurationClass()
和 #isLiteConfigurationClass()
.
方法的实现是去检查 BeanDefinition
中的 ConfigurationClassPostProcessor.configurationClass
属性, 是 full
还是 lite
.
这个属性的值又来源于 #checkConfigurationClassCandidate()
方法, 如果 BeanDefinition
使用的是 @Configuration
注解, 则为 full
; 如果是 @Component
, @ComponentScan
, @Import
或者 @ImportResource
中的任何一种, 则为 lite
. 如果是 ConfigurationClass
, 则会继续为其添加顺序属性.
public static boolean checkConfigurationClassCandidate(BeanDefinition beanDef, MetadataReaderFactory metadataReaderFactory) {
...
if (isFullConfigurationCandidate(metadata)) {
beanDef.setAttribute(CONFIGURATION_CLASS_ATTRIBUTE, CONFIGURATION_CLASS_FULL);
}
else if (isLiteConfigurationCandidate(metadata)) {
beanDef.setAttribute(CONFIGURATION_CLASS_ATTRIBUTE, CONFIGURATION_CLASS_LITE);
}
else {
return false;
}
// It's a full or lite configuration candidate... Let's determine the order value, if any.
Map<String, Object> orderAttributes = metadata.getAnnotationAttributes(Order.class.getName());
if (orderAttributes != null) {
beanDef.setAttribute(ORDER_ATTRIBUTE, orderAttributes.get(AnnotationUtils.VALUE));
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- Spring源码分析:@Autowired注解原理分析
- Spring AOP 源码解析:注解式切面增强机制
- Spring源码之注解扫描Component-scan
- Spring源码解读(3)AOP-切面类的注解处理
- SpringBoot2 | @SpringBootApplication注解 自动化配置流程源码分析(三)
- Spring 注解编程之模式注解
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
逆向工程权威指南
Dennis Yurichev(丹尼斯) / 安天安全研究与应急处理中心 / 人民邮电出版社 / 2017-3-1 / 168
逆向工程是一种分析目标系统的过程,旨在于识别系统的各组件以及组件间关系,以便于通过其它形式、或在较高的抽象层次上,重建系统的表征。 本书专注于软件的逆向工程,是写给初学者的一本经典指南。全书共分为12个部分,共102章,涉及X86/X64、ARM/ARM-64、MIPS、Java/JVM等重要话题,详细解析了Oracle RDBMS、Itanium、软件狗、LD_PRELOAD、栈溢出、EL......一起来看看 《逆向工程权威指南》 这本书的介绍吧!