@SpringBootApplication注釈が自動的にNの仕事以上実行することができ、なぜ次のコード、を見てください?
@EnableAsync
@SpringBootApplication
public class NimitzApplication {
public static void main(String[] args) {
new SpringApplicationBuilder(NimitzApplication.class).web(true).run(args);
}
}
プロセス
-
1 SpringApplication.run(オブジェクトソース、文字列引数...)
-
ConfigurableApplicationContextランで2つのコアプロセス(文字列...引数)
ApplicationArguments applicationArguments = new DefaultApplicationArguments(
args);
ConfigurableEnvironment environment = prepareEnvironment(listeners,
applicationArguments);
Banner printedBanner = printBanner(environment);
context = createApplicationContext();
analyzers = new FailureAnalyzers(context);
prepareContext(context, environment, listeners, applicationArguments,
printedBanner);
refreshContext(context);
afterRefresh(context, applicationArguments);
listeners.finished(context, null);
stopWatch.stop();
if (this.logStartupInfo) {
new StartupInfoLogger(this.mainApplicationClass)
.logStarted(getApplicationLog(), stopWatch);
}
- 3つの魔法のプロセス
SpringApplication.refreshContext
-> AbstractApplicationContext.invokeBeanFactoryPostProcessors(ConfigurableListableBeanFactory beanFactory)
-> PostProcessorRegistrationDelegate.invokeBeanDefinitionRegistryPostProcessors
-> ConfigurationClassPostProcessor.processConfigBeanDefinitions
-> ConfigurationClassParser.parse
-> ConfigurationClassParser.processConfigurationClass
// 最终 sourceClass是所有魔法的入口了
-> ConfigurationClassParser.doProcessConfigurationClass(configClass, sourceClass);
5 @import是最核心的注解,各种功能实际上是由三种类型的实现的
@Configuration classes, ImportSelector and ImportBeanDefinitionRegistrar implementations