循环依赖顾名思义多个类中的依赖形成了环路,形成了类似于死锁的情况,导致springboot在启动时无法为我们创建Bean。
1.循环依赖形成条件
使用构造方法的方式来注入依赖,并且类A中依赖类B,类B也同时依赖类A,这样两个类都无法正常进行Bean的创建,就会抛出异常:BeanCurrentlyInCreationException
@Component
public class A {
private B b;
@Autowired
public A(B b) {
this.b = b;
}
}
@Component
public class B {
private A a;
@Autowired
public B(A a) {
this.a = a;
}
}
2.循环依赖解决方法
1.使用setter注入代替构造器注入
2.使用lazy注解,延迟加载依赖
@Component
public class A {
private B b;
@Autowired
@Lazy
public A(B b) {
this.b = b;
}
}
@Component
public class B {
private A a;
@Autowired
@Lazy
public B(A a) {
this.a = a;
}
}
3.setter注入和构造器注入的比较
1.Constructor-based DI是强依赖(required dependencies)、会帮助判断注入的依赖是否为null、构造函数注入的组件需要以完全初始化的状态注入。
2.setter-based DI是可选依赖(optional dependencies)、不会判断null所以需要我们在代码中进行判断、setter注入可以使该类的对象在以后重新配置或重新注入。
如果要处理循环依赖问题,官方也建议我们使用setter注入方式。