我们从
AnnotationConfigApplicationContext
传入配置类的构造方法说起
首先this无参构造方法,这里先回调用父类的构造方法,里面创建了DefaultListableBeanFactory并复制给了成员变量beanFactory,然后回到本类的无参构造方法主要创建了Reader和Scanner
Reader中向bean定义Map中注册了六个处理注解的后置处理器类
接着调用register向bean定义Map中注册我们传入的配置类
接着调用refresh方法
这里重要的invokeBeanFactoryPostProcessor中
循环bean定义中的所有beanDefinition
分类顺序(PriorityOrder,Order等注解依次解析)搜出继承了PostProcessor的bean定义,并getBean创建对应的bean实例后塞进一个list中
接着循环list调用对应的后置处理器的处理方法
后置处理器的处理方法中又搜出了@Configuration的beanDefinition
并解析出里面对应的扫描路径
接着扫描我们配置路径下的对应类并封装成beanDefinition,put进BeanDefinitonMap中
此时,我们就已经完成了所有需要装载的bean定义的注册
在解析完bean定义之后,通过getBean获取bean定义对应的实例,getBean调用dogetBean,
首先从一级缓存中找,也就是单例缓存池,如果不存在
才从二级缓存中找,如果没找到,再到三级缓存中找
第一次肯定都没有,所以返回空继续执行下面的代码
getSingleton方法中传入ObjectFactory接口实现,
首先会调用在正在创建的Set集合中add进当前的beanname
调用ObjectFactroy中的getObject中定义的createBean
createBean又会调用doCreateBean,
接着根据bean定义中的class反射创建实例
以ObjectFactory形式放进三级缓存,
接着调用populateBean填充属性
解析对象中属性的字段对应的注解,根据字段名去getBean读取到对应的对象并 赋值给字段
而这里就会产生循环依赖度问题,
如果创建B依赖A,那么此时会去创建A,和上面一样的流程,但发现A填充属性的时候也依赖B ,那么当去二级缓冲中找时就会有不同,此时,我们可以在三级缓冲中找到B对应的ObjectFactory,通过getObject拿到对应的bean并填充到二级缓存删除三级缓存并返回,此时就可以拿到B的引用 ,填充完A的属性后,
最后执行A的初始化initializeBean,主要调用配置的初始化方法
删除二级缓存,把已经初始化完的Aput 进一级缓存中,完成A的创建
期间都会在每个需要的节点循环遍历BeanPostProcessor调用对应的节点方法,
也会判断下当前Bean是否实现了Aware方法,如果实现就调用对应的节点方法,
另外在
initApplicationEventMulticaster
也会初始化事件多播器,这里主要涉及事件监听机制
主要原理和后置处理器很相似,也是事先都先收集好所有的listener监听器
当有事件发布的时候,会遍历所有的监听器,把事件传进对应的方法中进行调用