Spring注解驱动开发——扩展原理

一. BeanFactoryPostProcessor

  • BeanPostProcessor:bean的后置处理器,bean创建对象初始化前后进行拦截工作的

  • BeanFactoryPostProcessor:BeanFactory的后置处理器,在BeanFactory的标准初始化之后调用所有bean的定义已经保存加载到BeanFactory,但是bean的实例还未创建

 BeanFactoryPostProcessor原理:
  1)、ioc容器创建对象
  2)invokeBeanFactoryPostProcessors(beanFactory);
  		如何找到所有的BeanFactoryPostProcessor并执行他们的方法;
  			1)、直接在BeanFactory中找到所有类型是BeanFactoryPostProcessor的组件,并执行他们的方法
  			2)、在初始化创建其他组件前面执行
@Component
public class MyBeanFactoryPostProcessor implements BeanFactoryPostProcessor {
    @Override
    public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
        System.out.println("MyBeanFactoryPostProcessor...PostProcessorBeanFactory...");
        int count = beanFactory.getBeanDefinitionCount();
        String[] beanDefinitionNames = beanFactory.getBeanDefinitionNames();
        System.out.println("当前的BeanFactory中有"+count+"个Bean");
        Stream.of(beanDefinitionNames).forEach(System.out::println);
    }
}
    @Test
    public void test01() {
        AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(ExtConfig.class);
    }

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

二. BeanDefinitionRegistryPostProcessor

  2BeanDefinitionRegistryPostProcessor extends BeanFactoryPostProcessor
  		postProcessBeanDefinitionRegistry();
  		在所有bean定义信息将要被加载,bean实例还未创建的;

  		优先于BeanFactoryPostProcessor执行;
  		利用BeanDefinitionRegistryPostProcessor给容器中再额外添加一些组件;

  	原理:
  		1)、ioc创建对象
  		2)、refresh()-invokeBeanFactoryPostProcessors(beanFactory);
  		3)、从容器中获取到所有的BeanDefinitionRegistryPostProcessor组件。
  			1、依次触发所有的postProcessBeanDefinitionRegistry()方法
  			2、再来触发postProcessBeanFactory()方法BeanFactoryPostProcessor4)、再来从容器中找到BeanFactoryPostProcessor组件;然后依次触发postProcessBeanFactory()方法
@Component
public class MyBeanDefinitionRegistryPostProcessor implements BeanDefinitionRegistryPostProcessor {

    @Override
    public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
        System.out.println("MyBeanDefinitionRegistryPostProcessor...bean的数量"+beanFactory.getBeanDefinitionCount());
    }

    //BeanDefinitionRegistry是bean定义信息的保存中心,以后BeanFactory就是按照BeanDefinitionRegistry里面保存的每一个bean的定义信息创建bean的实例
    @Override
    public void postProcessBeanDefinitionRegistry(BeanDefinitionRegistry registry) throws BeansException {
        System.out.println("MyBeanDefinitionRegistryPostProcessor...bean的数量"+registry.getBeanDefinitionCount());
        RootBeanDefinition beanDefinition = new RootBeanDefinition(Blue.class);
        registry.registerBeanDefinition("hello",beanDefinition);
    }
}

在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

三. ApplicationListener用法和原理

 3ApplicationListener:监听容器中发布的事件。事件驱动模型开发;
  	  public interface ApplicationListener<E extends ApplicationEvent>
  		监听 ApplicationEvent 及其下面的子事件;

  	 步骤:
  		1)、写一个监听器(ApplicationListener实现类)来监听某个事件(ApplicationEvent及其子类)
  			@EventListener;
  			原理:使用EventListenerMethodProcessor处理器来解析方法上的@EventListener2)、把监听器加入到容器;
  		3)、只要容器中有相关事件的发布,我们就能监听到这个事件;
  				ContextRefreshedEvent:容器刷新完成(所有bean都完全创建)会发布这个事件;
  				ContextClosedEvent:关闭容器会发布这个事件;
  		4)、发布一个事件:
  				applicationContext.publishEvent()
@Component
public class MyApplicationListener implements ApplicationListener<ApplicationEvent> {
    //当容器中发布次事件,方法触发
    @Override
    public void onApplicationEvent(ApplicationEvent event) {
        System.out.println("收到的事件"+event);
    }
}
    @Test
    public void test01() {
        AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(ExtConfig.class);
        applicationContext.close();
    }

在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

四. @EventListener与SmartInitializingSingleton

    SmartInitializingSingleton 原理:->afterSingletonsInstantiated();
    		1)、ioc容器创建对象并refresh()2)、finishBeanFactoryInitialization(beanFactory);初始化剩下的单实例bean;
    			1)、先创建所有的单实例bean;getBean();
    			2)、获取所有创建好的单实例bean,判断是否是SmartInitializingSingleton类型的;
    				如果是就调用afterSingletonsInstantiated();
@Service
public class UserService {
    @EventListener(classes = {ApplicationEvent.class})
    public void listen(ApplicationEvent event) {
        System.out.println("UserService监听的事件"+event);
    }
}

在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值