痛快!SpringBoot终于禁掉了循环依赖!

Java后端技术

共 2122字,需浏览 5分钟

 ·

2022-06-10 20:14

往期热门文章:

1、BigDecimal使用不当,造成P0事故!

2、Spring Boot 启动时自动执行代码的几种方式,还有谁不会??

3、VS Code 杀死 IDEA?!

4、服务器被恶意攻击是什么体验?

5、麻了!Fastjson 再曝反序列化漏洞。。

Spring的Bean管理,一直是整个体系中津津乐道的东西。尤其是Bean的循环依赖,更是很多面试官最喜欢考察的2B知识点之一。
但事实上,项目中存在Bean的循环依赖,是代码质量低下的表现。多数人寄希望于框架层来给擦屁股,造成了整个代码的设计越来越糟,最后用一些奇技淫巧来填补犯下的错误。
还好,SpringBoot终于受不了这种滥用,默认把循环依赖给禁用了!
从2.6版本开始,如果你的项目里还存在循环依赖,SpringBoot将拒绝启动!

验证代码小片段

为了验证这个功能,我们只需要两段小代码。
CircularDependencyA.java
@Component
@RequiredArgsConstructor
public class CircularDependencyA {
    private final CircularDependencyB circB;
}
CircularDependencyB.java
@Component
@RequiredArgsConstructor
public class CircularDependencyB {
    private final CircularDependencyA circA;
}
RequiredArgsConstructor注解,是lombok包里面的,用来实现简单的构造器注入。不出所料,当我们启动代码的时候,报错了~~
报错如下:
The dependencies of some of the beans in the application context form a cycle:
┌─────┐
|  circularDependencyA defined in file [cir/CircularDependencyA.class]
↑     ↓
|  circularDependencyB defined in file [cir/CircularDependencyB.class]
└─────┘

Action:

Relying upon circular references is discouraged and they are prohibited by defaultUpdate your application to remove the dependency cycle between beansAs a last resortit may be possible to break the cycle automatically by setting spring.main.allow-circular-references to true.
当然,有些鸟人已经玩大了,循环依赖到处都是,改代码变的越来越不现实。那你还可以通过在yaml里配置参数来临时开启循环依赖。
spring.main.allow-circular-references=true
看来SpringBoot对恶势力的容忍能力还是不够坚决啊!
绕过SpringBoot这个拦截的方法不止一种,比如使用@Lazy注解进行延迟初始化。但这些都是治标不治本,辜负了SpringBoot的一片苦心。

做对的事

其实,我们一直把代码往下找下去,会发现这个开关,其实是Spring的功能。
AbstractAutowireCapableBeanFactory#allowCircularReferences

/** Whether to automatically try to resolve circular references between beans. */
private boolean allowCircularReferences = true;
很长一段时间,SpringBoot这个值都是默认为true的。但这种纵容造成了大批低质量的代码产生,以至于新员工一直在给老员工擦屁股。
把这个值默认设置为false,是坚持做对的事情。起码,在工程师编写出质量不高的代码时,能够知道他自己在做什么,而不是把隐患一步步的推迟,任代码腐败。
不得不为SpringBoot点个赞。真棒!

往期热门文章:

1、MySQL 暴跌!

2、超越 Xshell!号称下一代 Terminal 终端神器,用完爱不释手!

3、IDEA 官宣全新默认 UI,太震撼了!!

4、让你直呼「卧槽」的 GitHub 项目!

5、Kafka又笨又重,为啥不选Redis?

6、50多个高频免费 API 接口分享

7、IDEA公司再发新神器!超越 VS Code 骚操作!

8、我怀疑这是 IDEA 的 BUG,但是我翻遍全网没找到证据!

9、Spring MVC 中的 Controller 是线程安全的吗?

10、Gitee 倒下了???

浏览 38
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报