总结自路神的讲解视频:
https://www.bilibili.com/video/BV1Ga4y1E7Br?from=search&seid=9678178918047026797
如何处理的:
spring进行扫描->
反射后封装成beanDefinition对象->
放入beanDefinitionMap->
遍历map->
验证(是否单例、是否延迟加载、是否抽象)->
推断构造方法->
准备开始进行实例->
去单例池中查,没有->
去二级缓存中找,没有提前暴露->
生成一个objectFactory对象暴露到二级缓存中->
属性注入,发现依赖Y->
此时Y开始它的生命周期直到属性注入,发现依赖X->
X又走一遍生命周期,当走到去二级缓存中找的时候找到了->
往Y中注入X的objectFactory对象->
打破循环依赖。
其中暴露的几个问题:
1、为什么要使用X的objectFacory对象而不是直接使用X对象?
利于拓展,程序员可以通过BeanPostProcessor接口操作objectFactory对象生成自己想要的对象
2、是不是只能支持单例(scope=singleton)而不支持原型(scope=prototype)?
是。因为单例是spring在启动时进行bean加载放入单例池中,在依赖的bean开始生命周期后,可以直接从二级缓存中取到它所依赖的bean的objectFactory对象从而结束循环依赖。而原型只有在用到时才会走生命周期流程,但是原型不存在一个已经实例化好的bean,所以会无限的创建->依赖->创建->依赖->...。
3、循环依赖是不是只支持非构造方法?
是。类似死锁问题