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

InstantiationAwareBeanPostProcessor的postProcessProperties和postProcessPropertyValues
这个就是我们所说的自动装配啦,内部的CommonAnnotationBeanPostProcessor和AutowiredAnnotationBeanPostProcessor处理器对注入的处理。


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初始化之后
和初始化之前处理类似,就不多说了。

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