zoukankan      html  css  js  c++  java
  • Spring源码解析之bean工厂后置处理器(BeanFactoryPostProcessor)和BeanDefinitionRegistryPostProcessor

    1、BeanFactoryPostProcessor是一个接口,它允许自定义修改应用程序上下文的bean定义,在基于bean factory上调整上下文的bean属性值。BeanFactoryPostProcessor可以与bean交互并修改bean定义,但从不使用bean实例。

    该接口有一个方法:void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException;

    该方法可以在应用程序上下文初始化之后修改bean factory。所有的bean定义都已经被加载了,但是还没有实例化bean,这样就可以覆盖或添加属性。

      实例:注入实现接口BeanFactoryPostProcessor的bean

     源码debug图解

    (1)、

    (2)、

    (3)、

    (4)、

    (5)、

    (6)、

    2、BeanDefinitionRegistryPostProcessor接口继承接口BeanFactoryPostProcessor,该接口新增postProcessBeanDefinitionRegistry方法,方法参数是BeanDefinitionRegistry对象,BeanDefinitionRegistry对象是bean定义的保存中心

      public void postProcessBeanDefinitionRegistry(BeanDefinitionRegistry registry) throws BeansException 

    实例:注入实现接口BeanFactoryPostProcessor的bean

    @Component
    public class MyBeanDefinitionRegistryPostProcessor implements BeanDefinitionRegistryPostProcessor {
        @Override
        public void postProcessBeanDefinitionRegistry(BeanDefinitionRegistry registry) throws BeansException {
            System.out.println("MyBeanDefinitionRegistryPostProcessor  :  postProcessBeanDefinitionRegistry");
            System.out.println(registry.getBeanDefinitionCount());
            RootBeanDefinition rootBeanDefinition = new RootBeanDefinition(AddedBean.class);
            registry.registerBeanDefinition("myaddBeanDefinition",rootBeanDefinition);
        }
    
        @Override
        public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
            System.out.println("MyBeanDefinitionRegistryPostProcessor  :  postProcessBeanFactory");
            System.out.println(beanFactory.getBeanDefinitionCount());
        }
    }
    

      

     源码debug图解

      1-4步和BeanFactoryPostProcessor接口的图解一致

      

  • 相关阅读:
    设计模式-抽象工厂模式
    装修预算-资料收集
    SQL中存储过程和函数的区别
    View
    数据表优化
    Entity Framework 基础
    html5标准
    JS整数验证
    vue 页面切换从右侧切入效果
    vue动态设置Iview的多个Input组件自动获取焦点
  • 原文地址:https://www.cnblogs.com/yaohuiqin/p/10399372.html
Copyright © 2011-2022 走看看