spring源码分析(八)——扩展原理

 2019-11-02 21:04  阅读(894)
文章分类:Spring boot
* 扩展原理:
    * BeanPostProcessor:bean后置处理器,bean创建对象初始化前后进行拦截工作的
    * 
    * 1、BeanFactoryPostProcessor:beanFactory的后置处理器;
    *     在BeanFactory标准初始化之后调用,来定制和修改BeanFactory的内容;
    *     所有的bean定义已经保存加载到beanFactory,但是bean的实例还未创建
    * 
    * 
    * BeanFactoryPostProcessor原理:
    * 1)、ioc容器创建对象
    * 2)、invokeBeanFactoryPostProcessors(beanFactory);
    *     如何找到所有的BeanFactoryPostProcessor并执行他们的方法;
    *        1)、直接在BeanFactory中找到所有类型是BeanFactoryPostProcessor的组件,并执行他们的方法
    *        2)、在初始化创建其他组件前面执行
    * 
    * 2、BeanDefinitionRegistryPostProcessor extends BeanFactoryPostProcessor
    *     postProcessBeanDefinitionRegistry();
    *     在所有bean定义信息将要被加载,bean实例还未创建的;
    * 
    *     优先于BeanFactoryPostProcessor执行;
    *     利用BeanDefinitionRegistryPostProcessor给容器中再额外添加一些组件;
    * 
    *  原理:
    *     1)、ioc创建对象
    *     2)、refresh()-》invokeBeanFactoryPostProcessors(beanFactory);
    *     3)、从容器中获取到所有的BeanDefinitionRegistryPostProcessor组件。
    *        1、依次触发所有的postProcessBeanDefinitionRegistry()方法
    *        2、再来触发postProcessBeanFactory()方法BeanFactoryPostProcessor;
    * 
    *     4)、再来从容器中找到BeanFactoryPostProcessor组件;然后依次触发postProcessBeanFactory()方法
    *  
    * 3、ApplicationListener:监听容器中发布的事件。事件驱动模型开发;
    *    public interface ApplicationListener<E extends ApplicationEvent>
    *     监听 ApplicationEvent 及其下面的子事件;
    * 
    *   步骤:
    *     1)、写一个监听器(ApplicationListener实现类)来监听某个事件(ApplicationEvent及其子类)
    *        @EventListener;
    *        原理:使用EventListenerMethodProcessor处理器来解析方法上的@EventListener;
    * 
    *     2)、把监听器加入到容器;
    *     3)、只要容器中有相关事件的发布,我们就能监听到这个事件;
    *           ContextRefreshedEvent:容器刷新完成(所有bean都完全创建)会发布这个事件;
    *           ContextClosedEvent:关闭容器会发布这个事件;
    *     4)、发布一个事件:
    *           applicationContext.publishEvent();
    *  
    *  原理:
    *      ContextRefreshedEvent、IOCTest_Ext$1[source=我发布的时间]、ContextClosedEvent;
    *  1)、ContextRefreshedEvent事件:
    *      1)、容器创建对象:refresh();
    *      2)、finishRefresh();容器刷新完成会发布ContextRefreshedEvent事件
    *  2)、自己发布事件;
    *  3)、容器关闭会发布ContextClosedEvent;
    *  
    *  【事件发布流程】:
    *      3)、publishEvent(new ContextRefreshedEvent(this));
    *            1)、获取事件的多播器(派发器):getApplicationEventMulticaster()
    *            2)、multicastEvent派发事件:
    *            3)、获取到所有的ApplicationListener;
    *               for (final ApplicationListener<?> listener : getApplicationListeners(event, type)) {
    *               1)、如果有Executor,可以支持使用Executor进行异步派发;
    *                  Executor executor = getTaskExecutor();
    *               2)、否则,同步的方式直接执行listener方法;invokeListener(listener, event);
    *                拿到listener回调onApplicationEvent方法;
    *  
    *  【事件多播器(派发器)】
    *      1)、容器创建对象:refresh();
    *      2)、initApplicationEventMulticaster();初始化ApplicationEventMulticaster;
    *         1)、先去容器中找有没有id=“applicationEventMulticaster”的组件;
    *         2)、如果没有this.applicationEventMulticaster = new SimpleApplicationEventMulticaster(beanFactory);
    *            并且加入到容器中,我们就可以在其他组件要派发事件,自动注入这个applicationEventMulticaster;
    *  
    *  【容器中有哪些监听器】
    *      1)、容器创建对象:refresh();
    *      2)、registerListeners();
    *         从容器中拿到所有的监听器,把他们注册到applicationEventMulticaster中;
    *         String[] listenerBeanNames = getBeanNamesForType(ApplicationListener.class, true, false);
    *         //将listener注册到ApplicationEventMulticaster中
    *         getApplicationEventMulticaster().addApplicationListenerBean(listenerBeanName);

*   SmartInitializingSingleton 原理:->afterSingletonsInstantiated();
    *         1)、ioc容器创建对象并refresh();
    *         2)、finishBeanFactoryInitialization(beanFactory);初始化剩下的单实例bean;
    *            1)、先创建所有的单实例bean;getBean();
    *            2)、获取所有创建好的单实例bean,判断是否是SmartInitializingSingleton类型的;
    *               如果是就调用afterSingletonsInstantiated();
    *

来源:http://ddrv.cn

点赞(0)
版权归原创作者所有,任何形式转载请联系作者; Java 技术驿站 >> spring源码分析(八)——扩展原理

相关推荐