2023-09-16
原文作者:王伟王胖胖 原文地址: https://blog.csdn.net/wangwei19871103/article/details/105175013

图不能少

202309162313447031.png

InstantiationAwareBeanPostProcessor的postProcessProperties和postProcessPropertyValues

这个就是我们所说的自动装配啦,内部的CommonAnnotationBeanPostProcessorAutowiredAnnotationBeanPostProcessor处理器对注入的处理。

202309162313453802.png

202309162313458353.png
postProcessPropertyValues已经过期了。

202309162313467174.png

202309162313470705.png
其实处理都差不多的。所以我们也可以在这里进行自己的扩展,对象都拿到了,还有啥干不了么是吧,具体就不演示了。

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

主要是设置一些属性,这里有个比较重要的就是BeanFactoryAware,可以获得BeanFactory

202309162313475406.png
比如我们自己实现一个也可以拿到这些信息,因为比较简单看下就好了:

202309162313479697.png

applyBeanPostProcessorsBeforeInitialization初始化之前

如果返回null的话就直接返回了,也就是不继续做处理了,所以这里其实可以组织其他处理器来处理,自定义处理器直接返回null,就返回了。

202309162313485118.png
其实也就是对bean的一些操作,没什么特殊的。

202309162313489239.png

invokeInitMethods执行初始化方法

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

2023091623134932010.png

invokeCustomInitMethod自定义的一些方法

也就是bean定义里设置了initMethodName

2023091623135001411.png

实战

随便定义个类写个方法:

    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();
        }

2023091623135041412.png

applyBeanPostProcessorsAfterInitialization初始化之后

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

2023091623135083013.png

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

阅读全文