用了好久的spring,对bean的生命周期一直 一知半解。今天百度谷歌详细了解了下,在此做个整理。
bean的生命周期
下面是我画的一个粗略的流程图
下面介绍几个关键的接口
1. BeanFactoryPostProcessor
这个接口只有一个实现方法,它只有一个方法postProcessBeanFactory。
void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException;
spring会在构造完beanFactory后执行这个方法(所有的bean尚未初始化),这时候如果我们想对beanFactory进行修改,就可以实现这个方法。
注意,如果在BeanFactoryPostProcessor中注入其他的bean对象,这些对象会提前初始化,但是初始化前后不会调用BeanPostProcessor接口的对应方法
2. BeanPostProcessor
再来看看BeanPostProcessor类,在BeanFactoryPostProcessor 的postProcessBeanFactory被执行后,实现BeanPostProcessor接口的对应类就会被构造了。我们再来看看这个接口的两个方法:
Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException;
Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException;
方法名写的很明确了,postProcessBeforeInitialization在bean初始化前会被调用,postProcessAfterInitialization在bean初始化后会被调用。
- 注意,初始化不是调用构造器构造类,这里的初始化指的是 bean调用InitializingBean的初始化方法或者调用
所以postProcessBeforeInitialization和postProcessAfterInitialization方法是在这两个执行前后执行的。
BeanPostProcessor的两个方法对所有bean都会起作用,也就是说,spring容器有几个bean,就会调用几次方法
3. InstantiationAwareBeanPostProcessor
这个接口其实就是 BeanPostProcessor 的扩展。多增加了bean实例构造前后执行的方法,和注入属性前执行的方法。
它比BeanPostProcessor多了下面这3个方法。
Object postProcessBeforeInstantiation(Class> beanClass, String beanName) throws BeansException;
boolean postProcessAfterInstantiation(Object bean, String beanName) throws BeansException;
PropertyValues postProcessPropertyValues(PropertyValues pvs, PropertyDescriptor[] pds, Object bean, String beanName) throws BeansException;
4. Aware 接口
如果bean 实现了BeanNameAware,BeanFactoryAware等接口,在注入完属性后会调用相应的接口方法。
比如BeanNameAware的setBeanName方法。BeanFactoryAware的setBeanFactory方法。
还有一个ApplicationContextAware接口也会在后面调用。
5. InitializingBean
如果bean实现了这个接口,那在bean注入属性完成后会执行对应的afterPropertiesSet方法。
6. DisposableBean
如果bean实现这个接口,那销毁的时候就会执行destroy方法。
下面总结一下
为了便于记忆,我们可以把上面的生命周期涉及到的类和接口归成3大类。
- 针对bean容器级别,也就是BeanFactoryPostProcessor这个接口,这个是在bean工厂构造后执行对应的方法。
- 针对所有bean级别,涉及所有bean构造前后,初始化前后的操作。也就是BeanPostProcessor和InstantiationAwareBeanPostProcessor接口。其中InstantiationAwareBeanPostProcessor其实也是BeanPostProcessor的一个子类,BeanPostProcessor本身是在类初始化前后执行对应的方法,InstantiationAwareBeanPostProcessor做了一些扩展,可以在类构造前后执行对应的方法。
- 最后,只针对某个类级别。BeanNameAware,BeanFactoryAware,ApplicationContextAware, InitializingBean,DisposableBean等接口都是针对某个bean的构造前后执行方法或者初始化前后执行方法。同样,在xml定义init-method方法或destory-method也是具体到某个bean。我们可以把它们都归到 Bean级别的接口方法上面
Bean的生命周期大体就这样了。有不对的地方烦请指出!