39、Spring5.x源码之旅三十九之初始化相关扩展点

  • 图不能少
  • InstantiationAwareBeanPostProcessor的postProcessProperties和postProcessPropertyValues
  • initializeBean的invokeAwareMethods注入完成开始初始化了
    • applyBeanPostProcessorsBeforeInitialization初始化之前
  • invokeInitMethods执行初始化方法
    • invokeCustomInitMethod自定义的一些方法
      • 实战
        • 测试代码
  • applyBeanPostProcessorsAfterInitialization初始化之后

图不能少

*

InstantiationAwareBeanPostProcessor的postProcessProperties和postProcessPropertyValues

这个就是我们所说的自动装配啦,内部的CommonAnnotationBeanPostProcessorAutowiredAnnotationBeanPostProcessor处理器对注入的处理。
*
*
postProcessPropertyValues已经过期了。
*
*
其实处理都差不多的。所以我们也可以在这里进行自己的扩展,对象都拿到了,还有啥干不了么是吧,具体就不演示了。

initializeBean的invokeAwareMethods注入完成开始初始化了

主要是设置一些属性,这里有个比较重要的就是BeanFactoryAware,可以获得BeanFactory
*
比如我们自己实现一个也可以拿到这些信息,因为比较简单看下就好了:
*

applyBeanPostProcessorsBeforeInitialization初始化之前

如果返回null的话就直接返回了,也就是不继续做处理了,所以这里其实可以组织其他处理器来处理,自定义处理器直接返回null,就返回了。
*
其实也就是对bean的一些操作,没什么特殊的。
*

invokeInitMethods执行初始化方法

主要还是执行实现了InitializingBean接口的afterPropertiesSet方法:
*

invokeCustomInitMethod自定义的一些方法

也就是bean定义里设置了initMethodName
*

实战

随便定义个类写个方法:

public class PoJo {
   
     
    public void init(){
   
     
        System.out.println("自定义initMethodName");
    }
}
测试代码

就是注册一个bean定义,然后设置InitMethodName

    @Test
    public void invokeCustomInitMethodTest() throws Exception {
   
     
        AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext();
        applicationContext.register(MyConfig.class);
        AnnotatedBeanDefinition annotatedBeanDefinition=new AnnotatedGenericBeanDefinition(PoJo.class);
        annotatedBeanDefinition.setInitMethodName("init");
        applicationContext.registerBeanDefinition("myBean",annotatedBeanDefinition);
        applicationContext.refresh();
    }

*

applyBeanPostProcessorsAfterInitialization初始化之后

和初始化之前处理类似,就不多说了。
*

好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。