Spring
bean的生命周期
总体来说分为 实例化 初始化 使用 销毁 四个步骤
1、 实例化bean:反射的方式生成对象(createBeanInstance)
2、 填充bean的属性:populateBean(),循环依赖问题
3、 调用aware接口相关方法:invokeAwareMethod(完成BeanName,Beanfactory,BeanClassLoader对象属性的赋值)
4、 调用BeanPostProcessor中的前置处理方法:使用比较多的有(ApplicationContextPostProcessor,设置ApplicationContext,Environment,ResourcceLoader)
5、 调用initMethod:判断是否实现了initializingBean接口,如果有调用afterPropertiesSet方法
6、 调用BeanPostProcessor的后置处理方法:spring的AOP就是在此处实现的,AbstractAutoProxyCreator 注册Destuction相关的回调接口
7、 获取到完整的对象:可以通过getBean的方式进行对象的获取
8、 销毁流程:判断是否实现了DisposableBean接口,调用destroyMethod方法
代码执行流程:
三级缓存
A对象有一个b属性,B对象有一个a属性;实例化A对象时b属性为空,初始化A对象填充b属性,此时从容器中找B对象,找不到则创建B对象,然后初始化B对象时填充a属性,同样到容器中找A对象,找不到继续创建这样就形成了闭环(循环依赖)。
但其实B对象在填充a属性时A对象在容器中已经存在,只是还未完成初始化,为了解决这个问题就需要提前暴露A对象的引用,把实例化和初始化分开,这样容器中就存在对象的两种状态,需要用两个不同的map进行存放,这就有二级缓存存放未初始化的对象,一级缓存存放完整的对象。三级缓存存放的是ObjectFactory对象,可以传入lambda表达式,只有在对象被引用的时候才判断返回代理对象还是返回原始对象。
debug方法
getBean → doGetBean→ createBean → doCreateBean→createBeanInstance→populateBean
三级缓存执行过程
传入ObjectFactory的lamda表达式,在调用getObject方法时调用createBean方法
将对象放入三级缓存
从三级缓存获取对象放入二级缓存,清除三级缓存数据
放到一级缓存删除二级缓存