作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO
联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬
学习必须往深处挖,挖的越深,基础越扎实!
阶段1、深入多线程
阶段2、深入多线程设计模式
阶段3、深入juc源码解析
码哥源码部分
码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】
码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】
码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】
码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】
打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】
图不能少
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初始化之后
和初始化之前处理类似,就不多说了。