依赖查找来源分为两类,一类通过SpringBeanDefinition生成的bean,一类是单例对象。
除了用户定义,Spring内建了一些beandefinition和单例对象
- Spring内建的BeanDefinition
在AnnotationConfigUtils类注册了一下BeanDefinition
- Spring内建单例对象
AbstractApplicationContext类里registerSingleton了一下bean
依赖注入多了一个非Spring容器管理对象,在容器refresh的时候往resolvableDependencies这个Map中。
AbstractApplicationContext类中有如下代码
// BeanFactory interface not registered as resolvable type in a plain factory. // MessageSource registered (and found for autowiring) as a bean. beanFactory.registerResolvableDependency(BeanFactory.class, beanFactory); beanFactory.registerResolvableDependency(ResourceLoader.class, this); beanFactory.registerResolvableDependency(ApplicationEventPublisher.class, this); beanFactory.registerResolvableDependency(ApplicationContext.class, this);
在依赖注入的时候使用到了这个resolvableDependency
// DefaultListableBeanFactory.java类 for (Map.Entry, Object> classObjectEntry : this.resolvableDependencies.entrySet()) { Class> autowiringType = classObjectEntry.getKey(); if (autowiringType.isAssignableFrom(requiredType)) { Object autowiringValue = classObjectEntry.getValue(); autowiringValue = AutowireUtils.resolveAutowiringValue(autowiringValue, requiredType); if (requiredType.isInstance(autowiringValue)) { result.put(ObjectUtils.identityToString(autowiringValue), autowiringValue); break; } } }
而在依赖查找时,不会去resolvableDependencies中去查找bean。
所以两者的依赖来源是不一样的。
单体对象就是就是比如messageSource,ResolvableDependency就是上一节的非Spring管理对象,又可以叫做 游离对象。
- BeanDefinitionRegistry#registerBeanDefinition,Bean生命周期顺序按照注册顺序
- SingletonBeanRegistry#registerSingleton, 限制: 无生命周期管理,无法实现延迟初始化Bean。
- ConfigurableListableBeanFactory#registerResolvableDependency,限制: 1.无生命周期管理,2.无法延迟初始化Bean。3.无法通过以来查找。
- 非常规Spring对象依赖来源,限制: 无生命周期管理,无法实现延迟初始化Bean,无法通过依赖查找。 @Value 就是。



