开始->调用BeanFactoryPostProcessor的postProcessBeanFactory方法对工厂定义信息进行后处理
->调用InstantiationAwareBeanPostProcessor的postProcessBeforeInstantiation()方法->实例化
->调用InstantiationAwareBeanPostProcessor的postProcessAfterInstantiation()方法
->调用InstantiationAwareBeanPostProcessor的postProcessPropertyValues()方法->设置属性值
->调用BeanNameAware的setBeanName()方法->调用BeanNameAware的setBeanFactory()方法
->调用ApplicationContext的setApplicationContext()方法
->调用BeanPostProcessor的postProcessBeforeInstantiation()方法->调用InitializingBean的afterPropertiesSet()方法
->通过init-method属性配置的初始化方法->调用BeanPostProcessor的postProcessAfterInstantiation()
|->prototype(将准备就绪的Bean交给调用者)
|->Singleton(Spring缓存池中准备就绪的Bean)->容器销毁(调用DisposableBean的afterPropertiesSet())
->通过destroy-method属性配置的销毁方法
1、如果配置文件中声明了工厂后处理接口BeanFactoryPostProcessor的实现类,则应用上下文在装配配置文件之后,初始化Bean之前,将调用这些BeanFactoryPostProcessor对配置信息进行进一步的处理。
Spring提供了多个工厂后处理器:CustomEditorConfiger、PropertyPlaceholderConfigurer等,如果在配置文件中定义了多个工厂后处理器,最好都继承ordered接口,Spring将以确定的顺序进行调用,工厂后处理器是容器级别的,仅在应用上下文初始化的时候调用一次,目的就是完成对一些文件的加工处理工作。
2、如果Bean实现了ApplicationContextAware接口,在Bean的生命周期中,会相应增加调用setApplicationContext()的过程;
3、ApplicationContext和BeanFactory另一个不同之处是前者利用java反射机制自动判断出配置文件中定义的BeanPostProcessor、InstantiationAwareBeanPostProcessor和BeanFactoryPostProcessor,并自动将其注册到应用上下文中,后才需要在代码中手动调用addBeanPostProcessor方法进行注册