DefaultListableBeanFactory 对配置lazy-init 属性单态Bean 的预实例化

//对配置lazy-init属性单态Bean的预实例化
@Override
public void preInstantiateSingletons() throws BeansException {
	if (this.logger.isDebugEnabled()) {
		this.logger.debug("Pre-instantiating singletons in " + this);
	}

	// Iterate over a copy to allow for init methods which in turn register new bean definitions.
	// While this may not be part of the regular factory bootstrap, it does otherwise work fine.
	List<String> beanNames = new ArrayList<>(this.beanDefinitionNames);

	// Trigger initialization of all non-lazy singleton beans...
	for (String beanName : beanNames) {
		//获取指定名称的Bean定义
		RootBeanDefinition bd = getMergedLocalBeanDefinition(beanName);
		//Bean不是抽象的,是单态模式的,且lazy-init属性配置为false
		if (!bd.isAbstract() && bd.isSingleton() && !bd.isLazyInit()) {
			//如果指定名称的bean是创建容器的Bean
			if (isFactoryBean(beanName)) {
				//FACTORY_BEAN_PREFIX=”&”,当Bean名称前面加”&”符号
				//时,获取的是产生容器对象本身,而不是容器产生的Bean.
				//调用getBean方法,触发容器对Bean实例化和依赖注入过程
				final FactoryBean<?> factory = (FactoryBean<?>) getBean(FACTORY_BEAN_PREFIX + beanName);
				//标识是否需要预实例化
				boolean isEagerInit;
				if (System.getSecurityManager() != null && factory instanceof SmartFactoryBean) {
					//一个匿名内部类
					isEagerInit = AccessController.doPrivileged((PrivilegedAction<Boolean>) () ->
							((SmartFactoryBean<?>) factory).isEagerInit(),
							getAccessControlContext());
				}
				else {
					isEagerInit = (factory instanceof SmartFactoryBean &&
							((SmartFactoryBean<?>) factory).isEagerInit());
				}
				if (isEagerInit) {
					//调用getBean方法,触发容器对Bean实例化和依赖注入过程
					getBean(beanName);
				}
			}
			else {
				getBean(beanName);
			}
		}
	}

	// Trigger post-initialization callback for all applicable beans...
	for (String beanName : beanNames) {
		Object singletonInstance = getSingleton(beanName);
		if (singletonInstance instanceof SmartInitializingSingleton) {
			final SmartInitializingSingleton smartSingleton = (SmartInitializingSingleton) singletonInstance;
			if (System.getSecurityManager() != null) {
				AccessController.doPrivileged((PrivilegedAction<Object>) () -> {
					smartSingleton.afterSingletonsInstantiated();
					return null;
				}, getAccessControlContext());
			}
			else {
				smartSingleton.afterSingletonsInstantiated();
			}
		}
	}
}

通过对lazy-init 处理源码的分析,我们可以看出,如果设置了lazy-init 属性,则容器在完成Bean 定义的注册之后,会通过getBean 方法,触发对指定Bean 的初始化和依赖注入过程,这样当应用第一次向容器索取所需的Bean 时,容器不再需要对Bean 进行初始化和依赖注入,直接从已经完成实例化和依赖注入的Bean 中取一个现成的Bean,这样就提高了第一次获取Bean 的性能。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值