痛快!SpringBoot終于禁掉了循環(huán)依賴!
Spring的Bean管理,一直是整個體系中津津樂道的東西。尤其是Bean的循環(huán)依賴,更是很多面試官最喜歡考察的2B知識點之一。
但事實上,項目中存在Bean的循環(huán)依賴,是代碼質(zhì)量低下的表現(xiàn)。多數(shù)人寄希望于框架層來給擦屁股,造成了整個代碼的設計越來越糟,最后用一些奇技淫巧來填補犯下的錯誤。
還好,SpringBoot終于受不了這種濫用,默認把循環(huán)依賴給禁用了!
從2.6版本開始,如果你的項目里還存在循環(huán)依賴,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包里面的,用來實現(xiàn)簡單的構(gòu)造器注入。不出所料,當我們啟動代碼的時候,報錯了~~
報錯如下:
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 default. Update your application to remove the dependency cycle between beans. As a last resort, it may be possible to break the cycle automatically by setting spring.main.allow-circular-references to true.
當然,有些鳥人已經(jīng)玩大了,循環(huán)依賴到處都是,改代碼變的越來越不現(xiàn)實。那你還可以通過在yaml里配置參數(shù)來臨時開啟循環(huán)依賴。
spring.main.allow-circular-references=true
看來SpringBoot對惡勢力的容忍能力還是不夠堅決啊!
繞過SpringBoot這個攔截的方法不止一種,比如使用@Lazy注解進行延遲初始化。但這些都是治標不治本,辜負了SpringBoot的一片苦心。
做對的事其實,我們一直把代碼往下找下去,會發(fā)現(xiàn)這個開關(guān),其實是Spring的功能。
AbstractAutowireCapableBeanFactory#allowCircularReferences
/** Whether to automatically try to resolve circular references between beans. */
private boolean allowCircularReferences = true;
很長一段時間,SpringBoot這個值都是默認為true的。但這種縱容造成了大批低質(zhì)量的代碼產(chǎn)生,以至于新員工一直在給老員工埋坑。
把這個值默認設置為false,是堅持做對的事情。起碼,在工程師編寫出質(zhì)量不高的代碼時,能夠知道他自己在做什么,而不是把隱患一步步的推遲,任代碼腐敗。
不得不為SpringBoot點個贊。真棒!
作者簡介:小姐姐味道 (xjjdog),一個不允許程序員走彎路的公眾號。聚焦基礎(chǔ)架構(gòu)和Linux。十年架構(gòu),日百億流量,與你探討高并發(fā)世界,給你不一樣的味道。