Spring源码学习之 三 getBean和后置处理器BeanPostProcessor9大调用点

作用

获取Spring容器中已初始化的bean,getBean一共有以下几种方法原型:

  1. Object getBean(String name)
  2. T getBean(String name, Class requiredType)
  3. Object getBean(String name, Object… args)
  4. T getBean(Class requiredType)
  5. T getBean(Class requiredType, Object… args)

主要流程图和Bean后置处理器9大调用点

在这里插入图片描述

三级缓存

public class DefaultSingletonBeanRegistry extends SimpleAliasRegistry implements SingletonBeanRegistry {
	/** Cache of singleton objects: bean name to bean instance. */
	// 一级缓存
	private final Map<String, Object> singletonObjects = new ConcurrentHashMap<>(256);

	/** Cache of singleton factories: bean name to ObjectFactory. */
	// 三级缓存
	private final Map<String, ObjectFactory<?>> singletonFactories = new HashMap<>(16);

	/** Cache of early singleton objects: bean name to bean instance. */
	// 二级缓存
	private final Map<String, Object> earlySingletonObjects = new HashMap<>(16);
}
  • 一级缓存:singletonObjects 存储的是所有创建好了的单例Bean
  • 二级缓存:earlySingletonObjects 完成实例化,但是还未进行属性注入及初始化的对象
  • 三级缓存:singletonFactories 提前暴露的一个单例工厂,二级缓存中存储的就是从这个工厂中获取到的对象

Spring 三级缓存放入二级缓存做了什么事情?
ObjectFactory.getObject() 触发 getEarlyBeanReference()方法之后才放入二级缓存;
getEarlyBeanReference():实际上就是调用了后置处理器的getEarlyBeanReference

为什么要使用三级缓存呢?二级缓存能解决循环依赖吗?
如果要使用二级缓存解决循环依赖,意味着所有Bean在实例化后就要完成AOP代理,这样违背了Spring设计的原则,Spring在设计之初就是通过AnnotationAwareAspectJAutoProxyCreator这个后置处理器来在Bean生命周期的最后一步来完成AOP代理,而不是在实例化后就立马进行AOP代理。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值