Spring支持所有循环依赖的情况吗?

循环依赖的情况如下:

  • 构造器循环依赖(singleton,prototype)
  • Setter注入循环依赖(singleton,prototype)

对于prototype来说,Spring是不支持相关的循环依赖的

观察doGetBean源码:

请添加图片描述

解决循环依赖的关键在于单例的三级缓存,三级缓存还保证了取出的bean的唯一性,所以三级缓存支持不了prototype

因为没有设置三级缓存进行支持:

  • 只能通过将Bean名字放入缓存里阻断无限循环

Spring只支持Singleton的setter循环依赖,即@Autowired形式,不支持构造器注入的循环依赖。

构造器注入:

1
2
java复制代码@Autowired
public Company(Staff staff){this.staff = staff;}

对于setter形式的注入,会来到doCreateBean
请添加图片描述
先将属性还没赋值的bean实例放入到三级缓存里,再调用

1
java复制代码populateBean(beanName, mbd, instanceWrapper);

注入里面的属性;但对于构造器方式来讲,不会等到populateBean才注入,而是在前面的

1
java复制代码instanceWrapper = createBeanInstance(beanName, mbd, args);

创建bean实例的时候时就创建出来的,此时还没缓存循环引用的另一个对象。

进入到createBeanInstance里,带参的构造函数的装配的位置
请添加图片描述
由于构造函数的参数实例并没被创建出来,在这个地方又会调用getBean尝试创建实例B,此时B的构造方法又需要A实例,就会造成上面doGetBean里抛异常。

本文转载自: 掘金

开发者博客 – 和开发相关的 这里全都有

0%