关于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的创建,最终完成整个流程。
这就是一个最简单的循环依赖的创建过程。