9
this.prepareContext(context, environment, listeners, applicationArguments, printedBanner);
老样子,点进去看看:
1context.setEnvironment(environment);
这一步不用多少,就是将环境变量set到context中,设置上下文的环境。
2this.postProcessApplicationContext(context);
这步操作主要是对ApplicationContext进行后置处理。那么做了哪些后置处理呢?我们点进去看下:
主要做了3部分:1.设置ApplicationContext的beanNameGenerator。2.设置ApplicationContext的ResourceLoader和ClassLoader。3.设置ApplicationContext类型转换service
3this.applyInitializers(context);
这个方法就是获取之前获取到的所有initializer类型的类,并进行初始化。
4listeners.contextPrepared(context);
这个方法是通知监听器 context 准备完成;
5if (this.logStartupInfo) { this.logStartupInfo(context.getParent() == null); this.logStartupProfileInfo(context); }
这个代码就是打印日志,这里不做过多描述。
6ConfigurableListableBeanFactory beanFactory = context.getBeanFactory();
这个方法就是获取DefaultListableBeanFactory的实例。
7`beanFactory.registerSingleton(“springApplicationArguments”, applicationArguments);``这步操作是注册了一个单例,单例名为“springApplicationArguments”,值为applicationArguments。8
if (printedBanner != null) {beanFactory.registerSingleton("springBootBanner", printedBanner);}
这步是判断printedBanner是否为空,如果不为空,就注册一个名为springBootBanner,值为printedBanner的单例
9if (beanFactory instanceof DefaultListableBeanFactory) {((DefaultListableBeanFactory)beanFactory).setAllowBeanDefinitionOverriding(this.allowBeanDefinitionOverriding);}
这个方法主要是配置bean如果重名,是否允许后一个bean覆盖前一个bean,默认是false,此时如果有同名的bean,注册到容器中,那么就会报异常。
10Set<Object> sources = this.getAllSources();
获取sources列表,这里可以获取到启动类的class
11this.load(context, sources.toArray(new Object[0]));
这个方法就是加载启动类,将启动类注入到容器里面。
12listeners.contextLoaded(context);
这个方法我们点进去看下:
这里就是将在SpringApplciation的Initialize()方法中注册的listener中属于ApplicationContextAware类型的bean都执行方法setApplicationContext,同时将这些Listener都加入到ApplicationContext中,并发布事件ApplicationPreparedEvent