Spring 擴展

/**
 * 擴展原理:
 * BeanPostProcessor:bean後置處理器,bean建立對象初始化先後進行攔截工做的
 * 
 * 一、BeanFactoryPostProcessor:beanFactory的後置處理器;
 *         在BeanFactory標準初始化以後調用,來定製和修改BeanFactory的內容;
 *         全部的bean定義已經保存加載到beanFactory,可是bean的實例還未建立
 * 
 * 
 * BeanFactoryPostProcessor原理:
 * 1)、ioc容器建立對象
 * 2)、invokeBeanFactoryPostProcessors(beanFactory);
 *         如何找到全部的BeanFactoryPostProcessor並執行他們的方法;
 *             1)、直接在BeanFactory中找到全部類型是BeanFactoryPostProcessor的組件,並執行他們的方法
 *             2)、在初始化建立其餘組件前面執行
 * 
 * 二、BeanDefinitionRegistryPostProcessor extends BeanFactoryPostProcessor
 *         postProcessBeanDefinitionRegistry();
 *         在全部bean定義信息將要被加載,bean實例還未建立的;
 * 
 *         優先於BeanFactoryPostProcessor執行;
 *         利用BeanDefinitionRegistryPostProcessor給容器中再額外添加一些組件;
 * 
 *     原理:
 *         1)、ioc建立對象
 *         2)、refresh()-》invokeBeanFactoryPostProcessors(beanFactory);
 *         3)、從容器中獲取到全部的BeanDefinitionRegistryPostProcessor組件。
 *             一、依次觸發全部的postProcessBeanDefinitionRegistry()方法
 *             二、再來觸發postProcessBeanFactory()方法BeanFactoryPostProcessor;
 * 
 *         4)、再來從容器中找到BeanFactoryPostProcessor組件;而後依次觸發postProcessBeanFactory()方法
 *     
 * 三、ApplicationListener:監聽容器中發佈的事件。事件驅動模型開發;
 *       public interface ApplicationListener<E extends ApplicationEvent>
 *         監聽 ApplicationEvent 及其下面的子事件;
 * 
 *      步驟:
 *         1)、寫一個監聽器(ApplicationListener實現類)來監聽某個事件(ApplicationEvent及其子類)
 *             @EventListener;
 *             原理:使用EventListenerMethodProcessor處理器來解析方法上的@EventListener;
 * 
 *         2)、把監聽器加入到容器;
 *         3)、只要容器中有相關事件的發佈,咱們就能監聽到這個事件;
 *                 ContextRefreshedEvent:容器刷新完成(全部bean都徹底建立)會發布這個事件;
 *                 ContextClosedEvent:關閉容器會發布這個事件;
 *         4)、發佈一個事件:
 *                 applicationContext.publishEvent();
 *     
 *  原理:
 *      ContextRefreshedEvent、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();
 *         
 * 
 *
 */
相關文章
相關標籤/搜索