我理解的Spring的循环依赖

一.具体过程:

所谓循环依赖,是指在两个类之间的相互引用,例如在A中引用B,B中引用A,那Spring容器在创建A时的步骤如下:
1)先从单例池中拿,这个单例池即我们经常说的spring容器,也可以称之为一级缓存,里面是一个map集合,装的是完整的bean
2)如果单例池中没有,那就会去调用createbean方法去创建,在创建的同时,把它放入一个set集合中,表示该类正在创建
3)在new 完A后,会先去判断是否支持循环引用,如果支持,就会先把这个new但是还没进行属性注入的A放到一个二级缓存中,我们把它称之为a,然后会发现需要引用到B
4)于是Spring就是创建B,就会又去走一遍1-3的步骤
5)但其实在第(2)步中,如果它从单例池里没拿到,那么它会去三级缓存中拿,去三级缓存中拿的条件是,要拿的这个bean在单例池里没有,且正在被创建,那到这里,B要A的话,是已经符合了这个条件,A在单例池中没有,且在第(2)步中已经表明A类正在被创建,所以可以从三级缓存中拿
6)但此时三级缓存中还是拿不到A
7)于是会从二级缓存中拿,而所谓的二级缓存就是一个beanfactory工厂,里面有一个getObject方法,可以获取到半成品的A,即在第(3)步中放入的a,拿到后,将这个a放入到三级缓存中,并将二级缓存中的a清除掉
8)拿到a后的B就可以进行自动注入了,自动注入完后返回到给A,继续完成A的创建

二.总结:

创建A----从一级缓存中拿-----没有----创建a(此时还没进行属性注入)----将a放到一个set中,表示该类正在被创建,且放到二级缓存中----创建B----在B中发现需要用到A-----从一级缓存中拿A----没拿到-----从三级缓存中拿—没拿到-----从二级缓存中拿----拿到了a-----将a放入到三级缓存中,并将二级缓存里的a清除掉—返回回去给B–完成B的创建-----完成A的创建

三.三个缓存的作用:

1.一级缓存是存放已经经历过完整生命周期的bean
2.二级缓存是存放new好但是还没进行属性注入的对象.二级缓存是个工厂类,这个工厂类可以对对象进行加工
3.三级缓存的放的已经在工厂中加工过的半成品对象,它的存在是为了提高性能,将加工过的对象缓存起来,省得重复创建

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值