基础结构和核心接口

目录

1.BeanDefinition

BeanDefinition 描述了一个Bean的实例,它记录了Bean的相关信息,并且可以设置以及获取Bean的内容,例如:Bean类名,Bean的作用域,Bean是否懒加载,,初始化方法名称,销毁方法名称,是否单例,是否原型,Bean属性值等等,直至根据BeanDefinition 生成Bean,可以说在Bean的管理中起到至关重要的作用

2.BeanDefinitionReader

看名称顾名思义是用来读取Bean的信息生成BeanDefinition 的信息并注册:

  • XmlBeanDefinitionReader: 用来解析Xml读取信息生成BeanDefinition并注册
  • AnnotatedBeanDefinitionReader: 读取注解生成BeanDefinition并注册
  • ClassPathBeanDefinitionScanner: 扫描类路径生成BeanDefinition并注册

这里的注册要分清楚不是注册Bean,可以理解为保存BeanDefination提供给后续的Bean生成使用

3.BeanDefinitionRegistry

看名称是BeanDefinition注册的接口,主要是对BeanDefinition做一个管理操作,例如注册、移除、获取等,实现了AliasRegistry,即还可以对Bean的别名进行管理

DefaultListableBeanFactory即是一个Bean的工厂同时也可以完成BeanDefination注册,这个是一个很重要的角色

4.BeanFactory

Bean工厂的根接口,提供了对Bean的基本操作,其实现类根据其特点基本实现了对Bean的各种操作;

以DefaultListableBeanFactory来看,基本上DefaultListableBeanFactory实现了工厂以及注册两大块类容,可以看出DefaultListableBeanFactory是多么重要的角色

从BeanFactory来看:

  • HierarchicalBeanFactory: 层次结构的BeanFactory提供两个方法getParentBeanFactory获取当前BeanFactory的父工厂,containsLocalBean当前BeanFactory是否包含指定名称的bean
  • ListableBeanFactory: 可罗列的BeanFactory,这里的可罗列意味着此BeanFactory提供类似于<T> Map<String, T> getBeansOfType (@Nullable Class<T> type)这种获取满足条件的一系列bean的功能
  • AutowireCapableBeanFactory: 具备自动装备功能的BeanFactory,提供了createBean实例化,属性填充,回调生命周期的创建bean,autowire自动装配bean,initializeBean 回调相关初始化方法,等方法
  • ConfigurableBeanFactory : 可配置的BeanFactory,提供了setParentBeanFactory ,setBeanClassLoader,addBeanPostProcessor等配置bean工厂的方法
  • ConfigurableListableBeanFactory: 实现了ListableBeanFactory ,AutowireCapableBeanFactory ,ConfigurableBeanFactory,具备其他三者的功能的同时,还提供了ignoreDependencyType 忽略给定依赖类型的自动装配,registerResolvableDependency 注册指定类型的依赖使用指定的对象进行注入等功能

5.ApplicationContext

这个可以说是Spring容器的启动入口了,总体来说也是一个BeanFactory,但其包含了更多的其他功能,实现了更多的扩展:

  • EnvironmentCapable: 提供获取Environment的能力
  • ResourceLoader: 用于加载资源(例如类路径或文件系统资源)的策略接口,根据路径获取资源包装成Resource
  • ResourcePatternResolver: ResourceLoader的子接口,提供根据路径匹配获取资源的能力
  • ApplicationEventPublisher : 事件发送接口
  • MessageSource: 用于解析消息的策略接口,用于实现国际化

两个重要的实现类:

  • AnnotationConfigApplicationContext: 基于注解包路径扫描的容器上下文,通过注解扫描来完成BeanDefinition的注册
  • ClassPathXmlApplicationContext: 基于类路径下xml文件的Spring应用程序上下文,通过解析类路径下的xml来完成BeanDefinition的注册

6.BeanPostProcessor

Bean后置处理器(重中之重!!!),内部有两个方法:

  • postProcessBeforeInitialization: Bean初始化前调用
  • postProcessAfterInitialization: Bean初始化后调用

源代码如下:

public interface BeanPostProcessor {
    @Nullable
    default Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
        return bean;
    }

    @Nullable
    default Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
        return bean;
    }
}

另一个实现了它的拓展接口InstantiationAwareBeanPostProcessor内部新增了4个方法:

  • postProcessBeforeInstantiation:Bean实例化前调用
  • postProcessAfterInstantiation:Bean实例化后调用
  • postProcessProperties:Bean属性注入的时候调用
  • postProcessPropertyValues:Bean属性注入的时候调用

源代码如下:

public interface InstantiationAwareBeanPostProcessor extends BeanPostProcessor {
    @Nullable
    default Object postProcessBeforeInstantiation(Class<?> beanClass, String beanName) throws BeansException {
        return null;
    }

    default boolean postProcessAfterInstantiation(Object bean, String beanName) throws BeansException {
        return true;
    }

    @Nullable
    default PropertyValues postProcessProperties(PropertyValues pvs, Object bean, String beanName) throws BeansException {
        return null;
    }

    /** @deprecated */
    @Deprecated
    @Nullable
    default PropertyValues postProcessPropertyValues(PropertyValues pvs, PropertyDescriptor[] pds, Object bean, String beanName) throws BeansException {
        return pvs;
    }
}

列举两个与我们平时息息相关的BeanPostProcessor:

  • AutowiredAnnotationBeanPostProcessor: 对@Autowired注解标识的做属性注入(此注解原理),还有其他注解例如: @Value,@Lookup,@Inject
  • CommonAnnoatationBeanPostProcessor: 与上面那个一样,但主要处理@Resource注解

📌这两个接口全是Bean的扩展点,在Bean的生命周期中发挥着至关重要的作用,所以这两个接口中的6个方法请记住,非常重要

7.BeanFactoryPostProcessor

源代码如下:

@FunctionalInterface
public interface BeanFactoryPostProcessor {
    void postProcessBeanFactory(ConfigurableListableBeanFactory var1) throws BeansException;
}

名称跟上面那位大哥很像,这个也是后置处理器,但是是BeanFactory的后置处理器,对BeanFactory相关信息可以做一些修改

使用目的:在BeanFactory标准初始化之后调用,用来定制和修改BeanFactory内的内容;

8.BeanDefinitionRegistryPostProcessor

public interface BeanDefinitionRegistryPostProcessor extends BeanFactoryPostProcessor {
    void postProcessBeanDefinitionRegistry(BeanDefinitionRegistry var1) throws BeansException;
}

继承了上面那位大哥,同样会在BeanFactory之后调用,但是内部多了个对BeanDefination处理的方法,该方法可以对BeanFactory中的BeanDefination做一次后置的统一处理,该方法执行顺序在postProcessBeanFactory之前

比如@Configuration注解的原理就是通过实现BeanDefinitionRegistryPostProcessor接口,然后扫描并生成BeanDefination并注册的,具体的实现类是ConfigurationClassPostProcessor

9.总结

上面的一些核心接口是不是都看懵逼了,不需要记得特别清楚,只需要知道个大概就行了:

解析Xml配置或者扫描注解生成BeanDefination加入到BeanFactory,BeanDefinitionRegistryPostProcessor对加入到BeanFactory的BeanDefination可以做增删改查操作,BeanFactoryPostProcessor可以对BeanFactory后置修改操作,然后会把BeanPostProcessor注册到BeanFactory中,最后根据BeanDefination生成Bean,在生成过程中BeanPostProcessor会起到作用

重点:分清楚BeanDefination和Bean的区别,理解几个后置处理器的生效位置

上面几个核心大概的执行顺序如下:

Last Updated: