问题
先上截图,idea报错信息:
在开发的过程中启动项目就报这个错误,这个错误的意思就是有两个类循环依赖了。
当一个类在初始化时需要另一个类的实例,而另一个类又需要第一个类的实例时,就会出现循环依赖问题,这会导致程序无法正确地初始化和运行。
解决
1. 重构代码
有可能是因为代码设计不合理,抽象不合理等等,但是重构代码影响的范围可能不可控,也要考虑时间成本。
2.去掉@Aysnc注解
使用了@Aysnc注解也可能会产生循环依赖的问题,因为使用@Aysnc的bean会产生一个代理类,导致注入的时候不是注入的同一个原始bean。
3.通过字段属性注入
@Autowired
private VacationPlanService vacationPlanService;
通过字段属性注入曾经是最常用的,也是最方便的,通过这种方法sping内部的三级缓存帮助我们解决了循环依赖问题,但是后来spring因使用字段注入破坏了封装性和可测试性而不推荐使用了。
4.使用@Lazy注解(推荐)
@Lazy注解用来表示延迟初始化bean,加了@Lazy注解后程序启动时spring就不会去初始化bean,这就解决了循环依赖的问题。
@Lazy一定要作用于构造方法或构造方法的参数上,我试过作用于类上但是没用。
@Service
public class StayPlanServiceImpl implements StayPlanService {
private final VacationPlanService vacationPlanService;
@Lazy
public StayPlanServiceImpl(VacationPlanService vacationPlanService){
this.vacationPlanService = vacationPlanService;
}
}
@Service
public class StayPlanServiceImpl implements StayPlanService {
private final VacationPlanService vacationPlanService;
public StayPlanServiceImpl(@Lazy VacationPlanService vacationPlanService){
this.vacationPlanService = vacationPlanService;
}
}
配合lombok的@RequiredArgsConstructor注解使用
@RequiredArgsConstructor(onConstructor_ = {@Lazy})
@Service
public class StayPlanServiceImpl implements StayPlanService {
final VacationPlanService vacationPlanService;
}