SpringBoot 的 run方法

SpringBoot 的run方法執(zhí)行谦絮,內(nèi)部執(zhí)行并未去徹底了解到,可能是自我的基礎(chǔ)未達到洁仗,很多思想都沒能去理解(大概也看有一周的時間了(當(dāng)然也不是每天一直看层皱,一天大概回去看一兩個小時)),純屬小白赠潦,這篇文章純屬筆記叫胖。

會先在堆中new 一個SpringApplication對象(并調(diào)用構(gòu)造器為SpringApplication(ResourceLoader resourceLoader, Class<?>... primarySources) ) 這里注意: SpringApplication中有部分靜態(tài)屬性、還有一些默認屬性回去加載她奥;

public SpringApplication(ResourceLoader resourceLoader, Class<?>... primarySources){ this.resourceLoader = resourceLoader; //資源加載器 默認傳參數(shù)為null Assert.notNull(primarySources, "PrimarySources must not be null"); // 用來判斷傳入的class是否為null瓮增、null則拋出String信息

this.primarySources = new LinkedHashSet<>(Arrays.asList(primarySources)); // 參數(shù)數(shù)組轉(zhuǎn)換為集合

this.webApplicationType = WebApplicationType.deduceFromClasspath(); // 映射以公共Java語言類名為鍵,對應(yīng)的類為值哩俭。

setInitializers((Collection) getSpringFactoriesInstances(ApplicationContextInitializer.class)); // 設(shè)置初始化類集合(spring工廠上下文)

setListeners((Collection) getSpringFactoriesInstances(ApplicationListener.class)); // 設(shè)置初始化監(jiān)聽對象(spring工廠)

this.mainApplicationClass = deduceMainApplicationClass(); // 返回堆棧中的main方法所在的class文件

}

// 初始話結(jié)束調(diào)用run()方法

public ConfigurableApplicationContext run(String... args) {

StopWatch stopWatch = new StopWatch(); //springboot中的計時對象 stopWatch.start(); // 計時開始

ConfigurableApplicationContext context = null; // 初始化配置對象 用于返回 Collection<SpringBootExceptionReporter> exceptionReporters = new ArrayList<>();// 初始化springboot異常記錄對象集合

configureHeadlessProperty();// 配置其它屬性

SpringApplicationRunListeners listeners = getRunListeners(args); // 配置運行時監(jiān)聽對象(屬性有日志對象绷跑,監(jiān)聽對象集合)

listeners.starting(); // 遍歷集合對象調(diào)用每個對象相應(yīng)的實現(xiàn)

try {

ApplicationArguments applicationArguments = new DefaultApplicationArguments(args);// 設(shè)置應(yīng)用參數(shù)

ConfigurableEnvironment environment = prepareEnvironment(listeners, applicationArguments); // 準(zhǔn)備環(huán)境(創(chuàng)建標(biāo)準(zhǔn)的服務(wù)環(huán)境StandardServletEnvironment[里面的屬性都是系統(tǒng)默認的]){ 獲取配置環(huán)境對象;配置環(huán)境對象凡资;spring應(yīng)用運行監(jiān)聽對象會為該環(huán)境對象做一些準(zhǔn)備工作砸捏;把該環(huán)境對象賦值給綁定對象的容器中; 判斷是否是定制的環(huán)境隙赁,不是則創(chuàng)建環(huán)境轉(zhuǎn)換器去調(diào)用convertEnvironmentIfNecessary(environment,deduceEnvironmentClass())進行轉(zhuǎn)換垦藏; 附加到環(huán)境屬性源上 }

configureIgnoreBeanInfo(environment); // 配置忽略對象信息

Banner printedBanner = printBanner(environment);

context = createApplicationContext(); // 創(chuàng)建應(yīng)用上下文(通過獲取上下文的class去創(chuàng)建對象)

exceptionReporters = getSpringFactoriesInstances(SpringBootExceptionReporter.class, new Class[] { ConfigurableApplicationContext.class }, context); // 獲取spring工廠的示例(通過獲取工廠集合中的class去一一創(chuàng) 建對象返回相應(yīng)的對象集合)

prepareContext(context, environment, listeners, applicationArguments, printedBanner); // 準(zhǔn)備上下文 { 設(shè)置上下文的環(huán)境;上下文對象配置伞访;初始化上下文掂骏;監(jiān)聽者上下文準(zhǔn)備(遍歷監(jiān)聽者集合為每個監(jiān)聽者調(diào)用各自的contextPrepared()方法); 啟動日志信息厚掷; } refreshContext(context); // 刷新上下文對象

afterRefresh(context, applicationArguments); // 之后刷新

stopWatch.stop(); // 計時結(jié)束

if (this.logStartupInfo) {

new StartupInfoLogger(this.mainApplicationClass).logStarted(getApplicationLog(), stopWatch); // 開啟一個日志對象

}

listeners.started(context); // 監(jiān)聽者開啟上下文(遍歷監(jiān)聽者集合為每個監(jiān)聽者調(diào)用各自的started()方法)

callRunners(context, applicationArguments);

} catch (Throwable ex) {

handleRunFailure(context, ex, exceptionReporters, listeners);

throw new IllegalStateException(ex);

}

try { listeners.running(context); }

catch (Throwable ex) {

handleRunFailure(context, ex, exceptionReporters, null);

throw new IllegalStateException(ex);

}

return context;

}

暫未整理完弟灼;

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蝗肪,隨后出現(xiàn)的幾起案子袜爪,更是在濱河造成了極大的恐慌蠕趁,老刑警劉巖薛闪,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異俺陋,居然都是意外死亡豁延,警方通過查閱死者的電腦和手機昙篙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诱咏,“玉大人苔可,你說我怎么就攤上這事〈” “怎么了焚辅?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長苟鸯。 經(jīng)常有香客問我同蜻,道長,這世上最難降的妖魔是什么早处? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任湾蔓,我火速辦了婚禮,結(jié)果婚禮上砌梆,老公的妹妹穿的比我還像新娘默责。我一直安慰自己,他們只是感情好咸包,可當(dāng)我...
    茶點故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布桃序。 她就那樣靜靜地躺著,像睡著了一般诉儒。 火紅的嫁衣襯著肌膚如雪葡缰。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天忱反,我揣著相機與錄音泛释,去河邊找鬼。 笑死温算,一個胖子當(dāng)著我的面吹牛怜校,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播注竿,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼茄茁,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了巩割?” 一聲冷哼從身側(cè)響起裙顽,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎宣谈,沒想到半個月后愈犹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年漩怎,在試婚紗的時候發(fā)現(xiàn)自己被綠了勋颖。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,785評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡勋锤,死狀恐怖饭玲,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情叁执,我是刑警寧澤茄厘,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站谈宛,受9級特大地震影響蚕断,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜入挣,卻給世界環(huán)境...
    茶點故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一亿乳、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧径筏,春花似錦葛假、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至恢氯,卻和暖如春带斑,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背勋拟。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工勋磕, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人敢靡。 一個月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓挂滓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親啸胧。 傳聞我的和親對象是個殘疾皇子赶站,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,713評論 2 354

推薦閱讀更多精彩內(nèi)容