SpringBean的生命周期以及循环依赖过程

上面就是springBean的大致生命周期。

Bean的创建过程

创建Bean之前会调用Bean工厂的后置处理器,可以获取到BeanDefinition

Bean的初始化过程

初始化之前会调用前置处理器,可以获取到BeanName和Bean实例

初始化之后会调用后置处理器,也是可以获取到BeanName和Bean实例,可以做一些属性的更改等

Bean的初始化也就是注入属性,这里会涉及到循环依赖的问题。spring默认是开启循环依赖的。

例如A依赖B,B依赖A

  1. 当创建A对象的时候,会调用getBeanSington()方法,也就是去单例池中查找有没有A的Bean,A还没创建成功,肯定没有。
  2. 调用下一个getBeanSington()方法,判断A对象是否正在被创建,也就是去查找set集合中有没有A对象,这时候也没有,然后将A加入set集合中
  3. 判断是否支持循环依赖,是否是单例,是的话将A放入singltonFactors也就是第二个map,其实这儿存的是一个工厂,后面就是通过这个工厂获取对象的
  4. 开始注入属性B
  5. 也是先去单例池中查找有没有B的Bean,也没有
  6. 判断B对象是否正在被创建,这时候也没有被创建,将B加入set集合中
  7. 判断是否支持循环依赖,是否是单例,是的话放入第二个map中,此时map中已经有A和B
  8. B也开始注入属性A
  9. 去单例池获取A的Bean,没有获取到
  10. 去set集合中获取A对象,获取到了,说明A正在被创建
  11. 去第二个map中获取到A的工厂,然后获取到对象,如果A对象做了代理,就会在这儿进行代理
  12. B对象注入属性A完成,如果B对象也做了代理的话,会再初始化完成之后进行AOP
  13. A对象此时就能从单例池中获取到B对象
  14. A对象万层初始化。

猜你喜欢

转载自www.cnblogs.com/jjpp/p/12377418.html