【Spring Boot】Spring Boot解决循环依赖

循环依赖问题概述

循环依赖指两个或多个Bean相互依赖,形成闭环。例如Bean A依赖Bean B,Bean B又依赖Bean A。Spring默认禁止循环依赖,但通过特定配置可解决部分场景。

解决方法

使用构造器注入+@Lazy注解 在构造器注入时配合@Lazy延迟加载可打破循环:

java 复制代码
@Service
public class ServiceA {
    private final ServiceB serviceB;
    
    @Autowired
    public ServiceA(@Lazy ServiceB serviceB) {
        this.serviceB = serviceB;
    }
}

改为Setter/Field注入 Spring对Setter/Field注入的循环依赖有内置处理机制:

java 复制代码
@Service
public class ServiceA {
    @Autowired
    private ServiceB serviceB;
}

调整代码结构 通过提取公共逻辑到第三方类,或使用接口分离依赖关系,从根本上消除循环。

配置调整

application.properties中显式开启循环依赖支持:

properties 复制代码
spring.main.allow-circular-references=true

注意事项

  • 构造器注入的循环依赖必须配合@Lazy
  • 循环依赖可能掩盖设计问题,应优先考虑重构
  • 原型(Prototype)作用域的Bean不支持循环依赖

最佳实践

推荐使用@Lazy结合Setter注入作为临时解决方案,同时通过以下方式优化设计:

  1. 应用依赖倒置原则(DIP)
  2. 引入事件驱动机制解耦
  3. 使用中间服务协调交互
相关推荐
陈随易几秒前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
许彰午1 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
陈随易1 小时前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
Bat U2 小时前
JavaEE|多线程初阶(七)
java·开发语言
大鱼七成饱2 小时前
VMware NAT模式下固定内网IP(附详细图文)
后端
IT_陈寒4 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
兔子零10245 小时前
手把手教你在 Claude Code 中接入 DeepSeek-V4
后端
掌心向暖RPA自动化5 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
日取其半万世不竭5 小时前
Minecraft Java版社区服务器搭建教程(Linux,适合新手)
java·linux·服务器
phenhorlin5 小时前
我做了个工具,让切换 Homebrew 镜像像切 npm 源一样简单
后端·shell