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

港控/mmm° 2021-09-27 22:12 441阅读 0赞
  1. * 扩展原理:
  2. * BeanPostProcessorbean后置处理器,bean创建对象初始化前后进行拦截工作的
  3. *
  4. * 1BeanFactoryPostProcessorbeanFactory的后置处理器;
  5. * BeanFactory标准初始化之后调用,来定制和修改BeanFactory的内容;
  6. * 所有的bean定义已经保存加载到beanFactory,但是bean的实例还未创建
  7. *
  8. *
  9. * BeanFactoryPostProcessor原理:
  10. * 1)、ioc容器创建对象
  11. * 2)、invokeBeanFactoryPostProcessors(beanFactory);
  12. * 如何找到所有的BeanFactoryPostProcessor并执行他们的方法;
  13. * 1)、直接在BeanFactory中找到所有类型是BeanFactoryPostProcessor的组件,并执行他们的方法
  14. * 2)、在初始化创建其他组件前面执行
  15. *
  16. * 2BeanDefinitionRegistryPostProcessor extends BeanFactoryPostProcessor
  17. * postProcessBeanDefinitionRegistry();
  18. * 在所有bean定义信息将要被加载,bean实例还未创建的;
  19. *
  20. * 优先于BeanFactoryPostProcessor执行;
  21. * 利用BeanDefinitionRegistryPostProcessor给容器中再额外添加一些组件;
  22. *
  23. * 原理:
  24. * 1)、ioc创建对象
  25. * 2)、refresh()-》invokeBeanFactoryPostProcessors(beanFactory);
  26. * 3)、从容器中获取到所有的BeanDefinitionRegistryPostProcessor组件。
  27. * 1、依次触发所有的postProcessBeanDefinitionRegistry()方法
  28. * 2、再来触发postProcessBeanFactory()方法BeanFactoryPostProcessor
  29. *
  30. * 4)、再来从容器中找到BeanFactoryPostProcessor组件;然后依次触发postProcessBeanFactory()方法
  31. *
  32. * 3ApplicationListener:监听容器中发布的事件。事件驱动模型开发;
  33. * public interface ApplicationListener<E extends ApplicationEvent>
  34. * 监听 ApplicationEvent 及其下面的子事件;
  35. *
  36. * 步骤:
  37. * 1)、写一个监听器(ApplicationListener实现类)来监听某个事件(ApplicationEvent及其子类)
  38. * @EventListener;
  39. * 原理:使用EventListenerMethodProcessor处理器来解析方法上的@EventListener
  40. *
  41. * 2)、把监听器加入到容器;
  42. * 3)、只要容器中有相关事件的发布,我们就能监听到这个事件;
  43. * ContextRefreshedEvent:容器刷新完成(所有bean都完全创建)会发布这个事件;
  44. * ContextClosedEvent:关闭容器会发布这个事件;
  45. * 4)、发布一个事件:
  46. * applicationContext.publishEvent();
  47. *
  48. * 原理:
  49. * ContextRefreshedEventIOCTest_Ext$1[source=我发布的时间]、ContextClosedEvent
  50. * 1)、ContextRefreshedEvent事件:
  51. * 1)、容器创建对象:refresh();
  52. * 2)、finishRefresh();容器刷新完成会发布ContextRefreshedEvent事件
  53. * 2)、自己发布事件;
  54. * 3)、容器关闭会发布ContextClosedEvent
  55. *
  56. * 【事件发布流程】:
  57. * 3)、publishEvent(new ContextRefreshedEvent(this));
  58. * 1)、获取事件的多播器(派发器):getApplicationEventMulticaster()
  59. * 2)、multicastEvent派发事件:
  60. * 3)、获取到所有的ApplicationListener
  61. * for (final ApplicationListener<?> listener : getApplicationListeners(event, type)) {
  62. * 1)、如果有Executor,可以支持使用Executor进行异步派发;
  63. * Executor executor = getTaskExecutor();
  64. * 2)、否则,同步的方式直接执行listener方法;invokeListener(listener, event);
  65. * 拿到listener回调onApplicationEvent方法;
  66. *
  67. * 【事件多播器(派发器)】
  68. * 1)、容器创建对象:refresh();
  69. * 2)、initApplicationEventMulticaster();初始化ApplicationEventMulticaster
  70. * 1)、先去容器中找有没有id=“applicationEventMulticaster”的组件;
  71. * 2)、如果没有this.applicationEventMulticaster = new SimpleApplicationEventMulticaster(beanFactory);
  72. * 并且加入到容器中,我们就可以在其他组件要派发事件,自动注入这个applicationEventMulticaster
  73. *
  74. * 【容器中有哪些监听器】
  75. * 1)、容器创建对象:refresh();
  76. * 2)、registerListeners();
  77. * 从容器中拿到所有的监听器,把他们注册到applicationEventMulticaster中;
  78. * String[] listenerBeanNames = getBeanNamesForType(ApplicationListener.class, true, false);
  79. * //将listener注册到ApplicationEventMulticaster中
  80. * getApplicationEventMulticaster().addApplicationListenerBean(listenerBeanName);
  81. * SmartInitializingSingleton 原理:->afterSingletonsInstantiated();
  82. * 1)、ioc容器创建对象并refresh();
  83. * 2)、finishBeanFactoryInitialization(beanFactory);初始化剩下的单实例bean
  84. * 1)、先创建所有的单实例beangetBean();
  85. * 2)、获取所有创建好的单实例bean,判断是否是SmartInitializingSingleton类型的;
  86. * 如果是就调用afterSingletonsInstantiated();
  87. *

发表评论

表情:
评论列表 (有 0 条评论,441人围观)

还没有评论,来说两句吧...

相关阅读