Spring是怎么解决循环依赖的?

Spring是通过三级缓存机制来解决循环依赖的。

我们可以把这三级缓存想象成3个不同等级的"货架":

其中,一级缓存存放的是成品货架,这里面都是完全初始化好,并且可以直接使用的Bean。

二级缓存存放的是半成品货架,这里面都是已经实例化好的,但是呢,还没有填充属性的Bean。

三级缓存存放的是工厂货架,这里放的就不是Bean了,而是一个可以生产Bean的工厂。

我们来理一下三级缓存解决循环依赖的流程:

假设A和B是相互依赖的,

首先,Spring先把A实例化出来,此时A还只是一个空壳,紧接着把一个可以获取A的工厂放到三级缓存里。

然后,A开始填充属性,这时发现需要B,所以就跑去创建B。

这时,B也实例化出来了,也开始填充属性,发现需要A。

然后,B就去一级缓存中寻找A,但是呢,没找到;所以又去二级缓存中寻找,也没找到;再跑去三级缓存中寻找,这下找到了。

这时,B就调用三级缓存中的工厂,拿到了A的引用。

为了保证是单例,只生产一次,B就把拿到的A放到二级缓存中,并把三级缓存中的工厂删掉。

B拿到了A后,B就创建完成了,入驻一级缓存。

A拿到B之后,A也可以创建完成,也可以入驻一级缓存。

相关推荐
ITOM运维行者12 分钟前
从零搭建企业级服务器监控体系:踩坑实录与架构设计
前端·后端
用户40993225021219 分钟前
Vue状态管理入门第四章:组合式store和SSR风险
前端·vue.js·后端
用户342323237631721 分钟前
SPI 通信与高速外设驱动详解
后端
魏祖潇1 小时前
SDD 完整指南——Spec 端打底、Story 端交付、留白区
人工智能·后端
feelmylife591 小时前
消息队列可靠投递与幂等消费 -- 从"消息丢了"到"消息别重复"的完整工程实践
后端
雪隐1 小时前
个人电脑玩AI-10让5060 Ti给你打工——部署 Odysseus:终于有个能打的"AI管家"了
人工智能·后端
荣码1 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
copyer_xyf2 小时前
FastAPI 如何连接 MySQL
后端·python
IT_陈寒2 小时前
Vite打包时踩的坑:静态资源为啥突然404了?
前端·人工智能·后端