zoukankan      html  css  js  c++  java
  • 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的创建,最终完成整个流程。

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

  • 相关阅读:
    题解 P2280 【[HNOI2003]激光炸弹】
    线段树求逆序对
    题解 P3378 【【模板】堆】
    动态规划-最大算式 蓝桥杯ALGO-116
    动态规划-树形动态规划-结点选择
    Trie树(字典树)-题解 P2580 【于是他错误的点名开始了】
    清北学堂-DAY2-数论专题-中国剩余定理(CRT)
    听课笔记--DP--Authentication Failed
    听课笔记--DP--最大子矩阵和
    多媒体基础
  • 原文地址:https://www.cnblogs.com/aquariusm/p/11169018.html
Copyright © 2011-2022 走看看