spring 源码跟踪笔记
最近下了个源码,在idea中跑,建了个测试项目,建了两个循环依赖的service,做代码跟踪。。。
以下是跑出来的demo的结果:
我在看源码时给自己提出了个问题:beanFactory是在啥时候创建的?
以下给出探索过程和结论:
但是AnnotationConfigApplicationContext的无参构造函数长这样:
实际上此时调用了父类GenericApplicationContext的无参构造函数实例化了beanFacotry:
也就是说没有AnnotationConfigApplicationContext的无参构造函数中没有调用super();但是却跑了GenericApplicationContext的无参构造函数,是不是很奇怪。。难道之前学的是知识是假的?这里可以提炼一个知识点出来??
这里可以总结出两个问题跟答案:
1.为什么AnnotationConfigApplicationContext无参构造函数没有实例化beanFactory,但是调用无参构造函数时,确实例化了beanFactory(beanFactory没有在声明时直接实例化)。
原因是:AnnotationConfigApplicationContext无参构造函数调用时触发了父类GenericApplicationContext的无参构造函数的执行,虽然没有调super();
2.为啥不调super(),却能触发父类的无参构造函数执行
原因可能是新的规范。
后面继续跟踪refresh方法了解spring框架启动过程!,走到哪里记录到哪里