spring循环依赖源码分析

23 篇文章 ¥15.90 ¥99.00
本文探讨了在Spring框架中遇到的循环依赖问题,通过分析源码揭示了Spring如何巧妙地解决这个问题。作者通过一个简单的X和Y类的示例,展示了在bean生命周期中,Spring如何利用多级缓存机制在bean创建过程中暂存部分对象,从而避免了死循环,成功完成了循环依赖的注入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

绪论

在使用spring或者springboot项目开发中,经常通过注入的方式完成一个bean对另一个bean的引用,比如classA中药注入B的bean,写法如下

@Autowired
private B b

而B中要注入A的话就是下面的写法了

@Autowired
private A a

用法非常简单,一目了然,用习惯了就成自然了,觉得就是那么回事,但小编最近读了点儿spring源码,就想搞清楚spring怎么就那么聪明,你那样用就可以完成注入呢?

现在我想探讨的是另一个问题,当在class A 中注入B,同时在class B中注入A,如果按照spring的bean的生命周期的过程去分析,发现这个问题竟然是循环依赖,按照我的理解和对spring ioc的一点研究,这就是成了死循环了啊,那么spring是怎么解决这个问题呢?这个问题很重要也很有意思,我们先来看看下面这张简图:
在这里插入图片描述

上述这幅图从直观的理解上描述了一个看似bug的问题,就是循环注入依赖,首先我们通过代码来看一个简单的例子吧,代码非常简单,两个被spring管理的类,一个启动类,一个配置类用于扫描包结构

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小码农叔叔

谢谢鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值