Spring 高级特性之二:后置处理器PostProcessor

  在Spring核心思想之 AOP:在自定义容器基础上实现AOP功能Spring核心思想之 AOP:如何影响DI并引入三级缓存解决DI中涉及代理的问题中都涉及了后置处理器。分析可知其影响盛广,在Spring中后置处理器,有哪些、分别在哪里使用、为什么这样用呢?

  Spring提供了如下后置处理器对容器中对象进行生命周期的管理:

    

   根据上图可知,实际bean对象涉及生命周期的主要是一个构造器和两个后置处理器(BeanFactoryPostProcessor和BeanPostProcessor)。我们以Dubbo框架为例验证上述结论,注解版配置类如下:

          

  关注@EnableDubbo中涉及bean生命周期的部分,跟踪发现涉及的后置处理器是beanFactoryPostProcessor有:

      DubboConfigAliasPostProcessor

      DubboConfigEarlyInitializationPostProcessor

  实例化:

 

   时序图:

   实例化成功后,在一级缓存中保存:

              

   那么调用呢?首先看下BeanFactoryPostProcessor接口的具体内容:

              

  那么确定postProcessBeanFactory的调用点即可。调试跟踪如下:

      

   以上跟踪调试分析,可知beanFactoryPostProcessor的实例化及调用均在refresh#invokeBeanFactoryPostProcessors中。

  类似,跟踪调试可分析出beanPostProcessor的实例化在refresh#registerBeanPostProcessors中,时序亦类似于beanFactoryPostProcessor。

  关于beanPostProcessor的调用,首先看下BeanPostProcessor接口的具体内容:

               

  其调用在哪里呢?以DubboConfigDefaultPropertyValueBeanPostProcessor这个bean后置处理器为例调试跟踪如下:

              

   上图总在finishBeanFactoryInitialization中初始化registryConfig的过程中调用了beanPostProcessor。其的调用过程可以参考责任链设计模式的相关内容(三、责任链模式 - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com))。

  BeanPostProcessor与BeanFactoryPostProcessor的初始化、调用的不同时机,正是由于它们的作用不同导致作用域不同决定的。BeanPostProcessor是针对Bean级别的处理,可以针对某个具体的Bean;而BeanFactoryPostProcessor针对整个Bean的工厂(BeanFactory)进⾏处理。可以具化想象成一个是对产品颜色、大小的修饰,一个是对生成产品的流水线进行修饰,比如添加润滑剂使半成品更快流向下一个环节等。
  关于构造器的使用就赘述了——单例新建的时候都需要用到私有的构造器,这个应该比较容易理解。

posted on 2021-07-07 02:06  池塘里洗澡的鸭子  阅读(587)  评论(0编辑  收藏  举报