spring源码阅读(2/4)

关于Bean的循环引用,昨天翻了相关的代码,确实一头雾水,看了部分的文章后,说实话,思路大概有点儿理解,但再来看代码仍然迷茫。没办法自己在测试例子里,写了个循环引用的例子,然后跟进调试代码,终于明白了点儿,今天就继续,把循环引用这个部分好好弄弄清楚。

翻了半天的代码,终于弄清楚了。

核心是:比如如果beanA和beanB互相依赖。我们来过一遍代码的执行流程

getBean("beanA")  ->  doGetBean("beanA")  ->  createBean("beanA")  ->  populateProperty("beanPro")  ->  getBean("beanB")  ->  doGetBean("beanB")  ->  createBean("beanB") -> populateProperty("beanPro")  ->  getBean("beanA")  ->  getSingleton("beanA")  -> singletonFactory.getObject("beanA")

流程类似这样,先去获取beanA,没有那么就创建,创建需要填充property,填充property时,发现有一个ref类型的引用,那么就去获取这个属性对应的beanB,返回到最开始的调用方法只是这次调用的是获取beanB,也是没有那么就创建,创建需要填充property,填充property时,发现又一个ref类型的引用,那么就去获取这个属性对应的beanA,再次返回到最开始的调用方法,这次调用的仍然是beanA,但是这次去执行getSingleton("beanA")的时候,因为我们第一次执行getBean("beanA")的时候,已经创建了ObjectFactroy,这次就会从objectFactory里获取object,这样有了beanA,那么beanB就可以正常创建了,beanB创建完了,就返回到beanA的属性填充的调用栈,继续beanA的创建,最终完成整个流程。

这就是一个最简单的循环依赖的创建过程。

原文地址:https://www.cnblogs.com/aquariusm/p/11169018.html