BeanA 依赖 BeanB 、BeanB 依赖 BeanA
getBeanA
1.先去三级缓存获取beanA
2.获取不到 创建beanA ==>将ObjectFactory 加入三级缓存
3.发现需要BeanB 接上下面流程
getBeanB
1.创建BeanB ,发现需要beanA成员变量注入
2.getBeanA 从三级缓存获取,删除三级缓存,加入二级缓存
3.初始化BeanB完成
4.加入 一级缓存
5.初始化BeanA完成
为什么是三级缓存而不是二级缓存?
1如果修改代码只用一级缓存(将实例化完成 和 初始化完成 的bean混合放一起),也可以,
但是正常不循环依赖的方法创建就都需要判断一遍 是否是 刚实例化(未赋值)= 存在循环依赖的Bean
逻辑不太合适,所以产生二级 作为 循环依赖的bean存储,代码逻辑清晰,还能解决 (2)
2.二级缓存和三级缓存是同时存在的,二级缓存为了防止每次三级缓存获取的实例不是同一个