2023-09-16  阅读(1)
原文作者:王伟王胖胖 原文地址: https://blog.csdn.net/wangwei19871103/article/details/105012594

执行剩下的BeanFactoryPostProcessor的后置处理器

首先先按PriorityOrderedOrdered和一般的BeanFactoryPostProcessor没处理过的处理器分成三个集合,然后按顺序分别进行处理,这里面除了我们自定义的,就是内部的EventListenerMethodProcessor了。

    String[] postProcessorNames =
    				beanFactory.getBeanNamesForType(BeanFactoryPostProcessor.class, true, false);
    		//三种优先级区分
    		// Separate between BeanFactoryPostProcessors that implement PriorityOrdered,
    		// Ordered, and the rest.
    		List<BeanFactoryPostProcessor> priorityOrderedPostProcessors = new ArrayList<>();
    		List<String> orderedPostProcessorNames = new ArrayList<>();
    		List<String> nonOrderedPostProcessorNames = new ArrayList<>();
    		for (String ppName : postProcessorNames) {
    			if (processedBeans.contains(ppName)) {//处理过的就不处理
    				// skip - already processed in first phase above
    			}
    			else if (beanFactory.isTypeMatch(ppName, PriorityOrdered.class)) {
    				priorityOrderedPostProcessors.add(beanFactory.getBean(ppName, BeanFactoryPostProcessor.class));
    			}
    			else if (beanFactory.isTypeMatch(ppName, Ordered.class)) {
    				orderedPostProcessorNames.add(ppName);
    			}
    			else {
    				nonOrderedPostProcessorNames.add(ppName);
    			}
    		}
    		//先处理priorityOrderedPostProcessors排序和回调
    		// First, invoke the BeanFactoryPostProcessors that implement PriorityOrdered.
    		sortPostProcessors(priorityOrderedPostProcessors, beanFactory);
    		invokeBeanFactoryPostProcessors(priorityOrderedPostProcessors, beanFactory);
    		//再处理orderedPostProcessors排序和回调
    		// Next, invoke the BeanFactoryPostProcessors that implement Ordered.
    		List<BeanFactoryPostProcessor> orderedPostProcessors = new ArrayList<>(orderedPostProcessorNames.size());
    		for (String postProcessorName : orderedPostProcessorNames) {
    			orderedPostProcessors.add(beanFactory.getBean(postProcessorName, BeanFactoryPostProcessor.class));
    		}
    		sortPostProcessors(orderedPostProcessors, beanFactory);
    		invokeBeanFactoryPostProcessors(orderedPostProcessors, beanFactory);
    		//最后是剩下的
    		// Finally, invoke all other BeanFactoryPostProcessors.
    		List<BeanFactoryPostProcessor> nonOrderedPostProcessors = new ArrayList<>(nonOrderedPostProcessorNames.size());
    		for (String postProcessorName : nonOrderedPostProcessorNames) {
    			nonOrderedPostProcessors.add(beanFactory.getBean(postProcessorName, BeanFactoryPostProcessor.class));
    		}
    		invokeBeanFactoryPostProcessors(nonOrderedPostProcessors, beanFactory);

EventListenerMethodProcessor的postProcessBeanFactory

bean名字中查找并创建EventListenerFactory类型的对象返回,然后保存到eventListenerFactories 中,其实就是创建事件监听工厂,后面可以创建事件监听器。

    	@Override
    	public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) {
    		this.beanFactory = beanFactory;
    
    		Map<String, EventListenerFactory> beans = beanFactory.getBeansOfType(EventListenerFactory.class, false, false);
    		List<EventListenerFactory> factories = new ArrayList<>(beans.values());
    		AnnotationAwareOrderComparator.sort(factories);
    		this.eventListenerFactories = factories;
    	}

DefaultListableBeanFactory的clearMetadataCache进行元数据缓存清除

主要是判断是否已经创建了,没创建的话BeanDefinitionstale=true,创建的就不处理了。最后把allBeanNamesByTypesingletonBeanNamesByType的缓存清除。

    	@Override
    	public void clearMetadataCache() {
    		super.clearMetadataCache();
    		clearByTypeCache();
    	}
    
    	public void clearMetadataCache() {
    		this.mergedBeanDefinitions.forEach((beanName, bd) -> {
    			if (!isBeanEligibleForMetadataCaching(beanName)) {
    				bd.stale = true;
    			}
    		});
    	}
    	private void clearByTypeCache() {
    		this.allBeanNamesByType.clear();
    		this.singletonBeanNamesByType.clear();
    	}

AbstractApplicationContext的invokeBeanFactoryPostProcessors

最后还要判断下是否要加入LoadTimeWeaverAwareProcessor处理器,这个暂时不重要。

    	protected void invokeBeanFactoryPostProcessors(ConfigurableListableBeanFactory beanFactory) {
    		PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(beanFactory, getBeanFactoryPostProcessors());
    
    		// Detect a LoadTimeWeaver and prepare for weaving, if found in the meantime
    		// (e.g. through an @Bean method registered by ConfigurationClassPostProcessor)
    		if (beanFactory.getTempClassLoader() == null && beanFactory.containsBean(LOAD_TIME_WEAVER_BEAN_NAME)) {
    			beanFactory.addBeanPostProcessor(new LoadTimeWeaverAwareProcessor(beanFactory));
    			beanFactory.setTempClassLoader(new ContextTypeMatchClassLoader(beanFactory.getBeanClassLoader()));
    		}
    	}

总结

至此调用BeanFactory的后置处理器全部完成了,我们来总结下,除去自定义的处理器,主要还是ConfigurationClassPostProcessor在处理,解析配置类,加载bean定义,配置类可能会进行CGLIB动态代理增强,最后把剩下的BeanFactoryPostProcessor处理器处理完:

202309162311558101.png
后面就要进行BeanPostProcessor后置处理器注册啦,这个就是用来参与bean创建的过程啦。

registerBeanPostProcessors注册bean后置处理器

其实这个里面跟invokeBeanFactoryPostProcessors差不多,都是有优先级别处理的,然后会进行排序注册,最后就是这样的:

202309162311562862.png

好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。


Java 面试宝典是大明哥全力打造的 Java 精品面试题,它是一份靠谱、强大、详细、经典的 Java 后端面试宝典。它不仅仅只是一道道面试题,而是一套完整的 Java 知识体系,一套你 Java 知识点的扫盲贴。

它的内容包括:

  • 大厂真题:Java 面试宝典里面的题目都是最近几年的高频的大厂面试真题。
  • 原创内容:Java 面试宝典内容全部都是大明哥原创,内容全面且通俗易懂,回答部分可以直接作为面试回答内容。
  • 持续更新:一次购买,永久有效。大明哥会持续更新 3+ 年,累计更新 1000+,宝典会不断迭代更新,保证最新、最全面。
  • 覆盖全面:本宝典累计更新 1000+,从 Java 入门到 Java 架构的高频面试题,实现 360° 全覆盖。
  • 不止面试:内容包含面试题解析、内容详解、知识扩展,它不仅仅只是一份面试题,更是一套完整的 Java 知识体系。
  • 宝典详情:https://www.yuque.com/chenssy/sike-java/xvlo920axlp7sf4k
  • 宝典总览:https://www.yuque.com/chenssy/sike-java/yogsehzntzgp4ly1
  • 宝典进展:https://www.yuque.com/chenssy/sike-java/en9ned7loo47z5aw

目前 Java 面试宝典累计更新 400+ 道,总字数 42w+。大明哥还在持续更新中,下图是大明哥在 2024-12 月份的更新情况:

想了解详情的小伙伴,扫描下面二维码加大明哥微信【daming091】咨询

同时,大明哥也整理一套目前市面最常见的热点面试题。微信搜[大明哥聊 Java]或扫描下方二维码关注大明哥的原创公众号[大明哥聊 Java] ,回复【面试题】 即可免费领取。

阅读全文