Spring有三级缓存:
第一级缓存:单例池SingletomObjects Map
二级缓存:eralySingletomObjects Map
(如果有aop逻辑,是不完整的代理对;如果没有aop,就是原始对象象),也是单例的。
三级缓存:singletonFactories
(这个lambda表达式执行的时候,就是获取对象填充二级缓存。)
注入的属性是对象时:
- 一级缓存找,找不到-》
- 二级缓存找,找不到,且出现了循环依赖-》
- 三级缓存找,找到了原始对象,aop生成原始对象的代理对象,存入二级缓存-》
注意:只有一级缓存是concurrentHashMap。原因:放入二级缓存和移出三级缓存时要整体保证原子性,就在外围用了syn同步代码块。
整体流程示意:
注意:
生成完整的bean之后,才会放入单例池。
属性注入的时候是要先去找单例池中找。(因为是单例池,所以注入的其实是引用)
提前aop的逻辑:
如果有aop逻辑,实例化之后就进行aop,保存在三级缓存中。
正常情况下aop的地方(会先判断是否提前进行过aop,如果进行过,就直接返回bean,并将其从Set中移除,就不再重新进行aop):
存入三级缓存的时期:
实例化后。
只要是单例bean,且正在创建,且允许循环依赖(默认),原始对象都会放入三级缓存中。
核心逻辑代码:
获取单例对象的方法getSingleton():
getSingleton()方法流程图:



