Spring扫描的源码解析
以下源码基于4.x版本进行分析
Spring的扫描基于ClassPathBeanDefinitionScanner。扫描对应的逻辑有该类的scan方法进行实现。接下来我们来看该类对应的源代码。主要的扫描逻辑都是在doScan方法中。
public int scan(String... basePackages) {
/**
* 还没有扫描mapper包之前 容器中所有的bean定义个数
*/
int beanCountAtScanStart = this.registry.getBeanDefinitionCount();
/**
* 真正的扫描我们的mapper包的mapper类
*/
doScan(basePackages);
// 注册系统中的配置类处理器
if (this.includeAnnotationConfig) {
AnnotationConfigUtils.registerAnnotationConfigProcessors(this.registry);
}
/**
* 返回扫描出mapper的bean定义的个数
*/
return (this.registry.getBeanDefinitionCount() - beanCountAtScanStart);
}
接下来在键入doScan方法中进行源代码的查看。大致脉络为,循环包路径的集合,找到满足条件的BeanDefinition。在对这些满足条件的BeanDefinition进行属性的赋值后对其进行注册。
protected Set<BeanDefinitionHolder> doScan(String... basePackages) {
Assert.notEmpty(basePackages, "At least one base package must be specified");
//创建bean定义的holder对象用于保存扫描后生成的bean定义对象
Set<BeanDefinitionHolder> beanDefinitions = new LinkedHashSet<>();
//循环我们的包路径集合
for (String basePackage : basePackages) {
//找到候选的Compents
Set<BeanDefinition> candidates = findCandidateComponents