spring 源码跟踪笔记

  最近下了个源码,在idea中跑,建了个测试项目,建了两个循环依赖的service,做代码跟踪。。。

spring 源码跟踪笔记

spring 源码跟踪笔记

spring 源码跟踪笔记

 

spring 源码跟踪笔记

 

以下是跑出来的demo的结果:

spring 源码跟踪笔记

 

 

我在看源码时给自己提出了个问题:beanFactory是在啥时候创建的? 

以下给出探索过程和结论:

spring 源码跟踪笔记

 

但是AnnotationConfigApplicationContext的无参构造函数长这样:

spring 源码跟踪笔记

实际上此时调用了父类GenericApplicationContext的无参构造函数实例化了beanFacotry:

spring 源码跟踪笔记

也就是说没有AnnotationConfigApplicationContext的无参构造函数中没有调用super();但是却跑了GenericApplicationContext的无参构造函数,是不是很奇怪。。难道之前学的是知识是假的?这里可以提炼一个知识点出来??

 

这里可以总结出两个问题跟答案:
1.为什么AnnotationConfigApplicationContext无参构造函数没有实例化beanFactory,但是调用无参构造函数时,确实例化了beanFactory(beanFactory没有在声明时直接实例化)。

   原因是:AnnotationConfigApplicationContext无参构造函数调用时触发了父类GenericApplicationContext的无参构造函数的执行,虽然没有调super();

 

2.为啥不调super(),却能触发父类的无参构造函数执行

   原因可能是新的规范。

 

 

后面继续跟踪refresh方法了解spring框架启动过程!,走到哪里记录到哪里