源码阅读 - ClassPathXmlApplicationContext解析(三)

本文详细探讨了Spring框架中ClassPathXmlApplicationContext的初始化过程,包括prepareBeanFactory、registerSingleton、postProcessBeanFactory等关键步骤。通过源码分析,揭示了bean的加载、注册、后处理等核心机制,帮助理解Spring容器的工作原理。
摘要由CSDN通过智能技术生成

本文概述

上文 BeanFactory的初始化、加载、注册过程 主要介绍容器初始化refresh函数中prepareRefresh(),obtainFreshBeanFactory()方法,本文将继续介绍refresh函数下其他的方法。

因这部分比较复杂,本文还在整理中,请各位见谅!!!

源码阅读

prepareBeanFactory(beanFactory);

配置工厂的标准上下文特征,比如类加载器和后置处理器。

	protected void prepareBeanFactory(ConfigurableListableBeanFactory beanFactory) {
   
		beanFactory.setBeanClassLoader(getClassLoader());   // 设置类加载器
		beanFactory.setBeanExpressionResolver(new StandardBeanExpressionResolver(beanFactory.getBeanClassLoader())); 
		beanFactory.addPropertyEditorRegistrar(new ResourceEditorRegistrar(this, getEnvironment()));  

		beanFactory.addBeanPostProcessor(new ApplicationContextAwareProcessor(this)); // 配置回调,在List中添加实例
		//如果某个 bean 依赖于以下几个接口的实现类,在自动装配的时候忽略它们,Spring 会通过其他方式来处理这些依赖,在Set<Class>中添加实例。
		beanFactory.ignoreDependencyInterface(EnvironmentAware.class);  
		beanFactory.ignoreDependencyInterface(EmbeddedValueResolverAware.class);
		beanFactory.ignoreDependencyInterface(ResourceLoaderAware.class);
		beanFactory.ignoreDependencyInterface(ApplicationEventPublisherAware.class);
		beanFactory.ignoreDependencyInterface(MessageSourceAware.class);
		beanFactory.ignoreDependencyInterface(ApplicationContextAware.class);

		// 注册,第一个参数为类型,第二个参数为自动装配的值。这适用于应该是可自动装配但未在工厂中定义为 bean 的工厂/上下文引用,在Map放(K,V)键值对。
		beanFactory.registerResolvableDependency(BeanFactory.class, beanFactory);
		beanFactory.registerResolvableDependency(ResourceLoader.class, this);
		beanFactory.registerResolvableDependency(ApplicationEventPublisher.class, this);
		beanFactory.registerResolvableDependency(ApplicationContext.class, this);

		// 增加Bean后置处理器
		beanFactory.addBeanPostProcessor(new ApplicationListenerDetector(this));

		// 可能会注册 LoadTimeWeaverAwareProcessor
		if (beanFactory.containsBean(LOAD_TIME_WEAVER_BEAN_NAME)) {
   
			beanFactory.addBeanPostProcessor(new LoadTimeWeaverAwareProcessor(beanFactory));
			beanFactory.setTempClassLoader(new ContextTypeMatchClassLoader(beanFactory.getBeanClassLoader()));
		}

		// 手动注册环境的beans,继续跟进代码
		if (!beanFactory.containsLocalBean(ENVIRONMENT_BEAN_NAME)) {
   
			beanFactory.registerSingleton(ENVIRONMENT_BEAN_NAME, getEnvironment());
		}
		if (!beanFactory.containsLocalBean(SYSTEM_PROPERTIES_BEAN_NAME)) {
   
			beanFactory.registerSingleton(SYSTEM_PROPERTIES_BEAN_NAME, getEnvironment().getSystemProperties());
		}
		if (!beanFactory.containsLocalBean(SYSTEM_ENVIRONMENT_BEAN_NAME)) {
   
			beanFactory.registerSingleton(SYSTEM_ENVIRONMENT_BEAN_NAME, getEnvironment().getSystemEnvironment());
		}
	}

registerSingleton(beanName, singletonObject);

将给定的现有对象在bean注册表中以给定的bean名称注册为单例对象。

	@Override
	public void registerSingleton(String beanName, Object singletonObject) throws IllegalStateException {
   
		super.registerSingleton(beanName, singletonObject);
		updateManualSingletonNames(set -> set.add(beanName), set -> !this.beanDefinitionMap.containsKey(beanName));
		clearByTypeCache();
	}
super.registerSingleton
	public void registerSingleton(String beanName, Object singletonObject) throws IllegalStateException {
   
		Assert.notNull(beanName, "Bean name must not be null");
		Assert.notNull(singletonObject, "Singleton object must not be null");
		synchronized (this.singletonObjects) {
   
			Object oldObject = this.singletonObjects.get(beanName);  //检查有没有定义过
			if (oldObject != null) {
   
				throw new IllegalStateException("Could not register object [" + singletonObject +
						"] under bean name '" + beanName + "': there is already object [" + oldObject + "] bound");
			}
			addSingleton(beanName, singletonObject);  //继续跟进
		}
	}
	protected void addSingleton(String beanName, Object singletonObject) {
   
		synchronized (this.singletonObjects) {
   
			this.singletonObjects.put(beanName, singletonObject);  //放进ConcurrentHashMap
			this.singletonFactories.remove(beanName);  //从HashMap删除
			this.earlySingletonObjects.remove(beanName);  //从HashMap删除
			this.registeredSingletons.add(beanName);  //放进LinkedHashSet
		}
	}
updateManualSingletonNames
	private void updateManualSingletonNames(Consumer<Set<String>> action, Predicate<Set<String>> condition) {
   
		if (hasBeanCreationStarted()) {
   
			// 无法再修改启动时集合元素(用于稳定迭代)
			synchronized (this.beanDefinitionMap) {
   
				if (condition.test(this.manualSingletonNames)) {
   
					Set<String> updatedSingletons = new LinkedHashSet<>(this.manualSingletonNames);
					action.accept(updatedSingletons);
					this.manualSingletonNames = updatedSingletons;
				}
			}
		}
		else {
    //启动注册阶段
			if (condition.test(this.manualSingletonNames)) {
   
				action.accept(this.manualSingletonNames);
			}
		}
	}
clearByTypeCache

删除所有的类型映射。

	private void clearByTypeCache() {
   
		this.allBeanNamesByType.clear();
		this.singletonBeanNamesByType.clear();
	}

postProcessBeanFactory(beanFactory);

默认为空方法,作用是在标准化的初始化之后修改下下文 的内部bean factory。
此时所有的bean都加载好了,在一些ApplicationContext实现中,可以加BeanPostProcessor,或者注册可解析依赖项。

invokeBeanFactoryPostProcessors(beanFactory);

实例化、执行所有注册过的BeanFactoryPostProcessor 。

	protected void invokeBeanFactoryPostProcessors(ConfigurableListableBeanFactory beanFactory) {
   
		PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(beanFactory, getBeanFactoryPostProcessors());  //继续跟进

		// 检查LoadTimeWeaver和类加载器,并准备编织
		if (beanFactory.getTempClassLoader() == null && beanFactory.containsBean(LOAD_TIME_WEAVER_BEAN_NAME)) {
   
			beanFactory.addBeanPostProcessor(new LoadTimeWeaverAwareProcessor(beanFactory));
			beanFactory.setTempClassLoader(new ContextTypeMatchClassLoader(beanFactory.getBeanClassLoader()));
		}
	}
	public static void invokeBeanFactoryPostProcessors(
			ConfigurableListableBeanFactory beanFactory, List<BeanFactoryPostProcessor> beanFactoryPostProcessors) {
   

		// 先执行BeanDefinitionRegistryPostProcessors
		Set<String> processedBeans = new HashSet<>();

		if (beanFactory instanceof BeanDefinitionRegistry) {
     //如果是BeanDefinitionRegistry的实例
			BeanDefinitionRegistry registry = (BeanDefinitionRegistry) beanFactory;
			List<BeanFactoryPostProcessor> regularPostProcessors = new ArrayList<>();
			List<BeanDefinitionRegistryPostProcessor> registryProcessors = new ArrayList<>();

			for (BeanFactoryPostProcessor postProcessor : beanFactoryPostProcessors) {
    
				if (postProcessor instanceof BeanDefinitionRegistryPostProcessor) {
      //如果List中的元素是BeanDefinitionRegistryPostProcessor
					BeanDefinitionRegistryPostProcessor registryProcessor =
							(BeanDefinitionRegistryPostProcessor) postProcessor;
					registryProcessor.postProcessBeanDefinitionRegistry(registry);
					registryProcessors.add(registryProcessor);
				}
				else {
   
					regularPostProcessors.add(postProcessor);
				}
			}

			// 不要在这初始化FactoryBeans,保持Beans未初始化状态,以保证bean factory的post-processors生效。分别实现了三种BeanDefinitionRegistryPostProcessors :PriorityOrdered, Ordered, and the rest。
			List<BeanDefinitionRegistryPostProcessor> currentRegistryProcessors = new ArrayList<>();

			// 首先执行实现PriorityOrdered的 BeanDefinitionRegistryPostProcessors
			String[] postProcessorNames =
					beanFactory.getBeanNamesForType(BeanDefinitionRegistryPostProcessor.class, true, false);
			for (String ppName : postProcessorNames) {
   
				if (beanFactory.isTypeMatch(ppName, PriorityOrdered.class)) {
   
					currentRegistryProcessors.add(beanFactory.getBean(ppName, BeanDefinitionRegistryPostProcessor.class));
					processedBeans.add(ppName);
				}
			}
			sortPostProcessors(currentRegistryProcessors, beanFactory);
			registryProcessors.addAll(currentRegistryProcessors);
			invokeBeanDefinitionRegistryPostProcessors(currentRegistryProcessors, registry);
			currentRegistryProcessors.clear();

			// 首先执行实现Ordered的 BeanDefinitionRegistryPostProcessors  
			postProcessorNames = beanFactory.getBeanNamesForType(BeanDefinitionRegistryPostProcessor.class, true, false);
			for (String ppName : postProcessorNames) {
   
				i
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

洛阳八中我最棒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值