Springboot自動配置與@Configuration配置類詳解
@Configuration
注意點1
配置類(@Configuration下的這個類)其實相當(dāng)于一個工廠, 標(biāo)注 @Bean 注解的方法相當(dāng)于工廠方法
考慮有如下例子:
@Configuration // 注意點1: 配置類其實相當(dāng)于一個工廠, 標(biāo)注 @Bean 注解的方法相當(dāng)于工廠方法 static class MyConfig { @Bean public Bean1 bean1() { System.out.println("bean1()"); return new Bean1(); }
將來如果要生成一個bean1的實例,首先要找到一個叫myConfig的bean(是一個工廠),再調(diào)用這個工廠里面叫"bean1"的方法,生成bean1對象。
對于沒有static修飾的@Bean工廠方法,叫做實例工廠,需要先把配置類myConfig實例創(chuàng)建出來;有static修飾的是靜態(tài)方法,只需要拿到myConfig的類對象,然后直接.方法就行。
注意點2
@Bean 不支持方法重載, 如果有多個重載方法, 僅有一個能入選為工廠方法
@Configuration @MapperScan("aaa") // 注意點1: 配置類其實相當(dāng)于一個工廠, 標(biāo)注 @Bean 注解的方法相當(dāng)于工廠方法 static class MyConfig { // 注意點2: @Bean 不支持方法重載, 如果有多個重載方法, 僅有一個能入選為工廠方法 @Bean public Bean1 bean1() { System.out.println("bean1()"); return new Bean1(); } @Bean public Bean1 bean1(@Value("${java.class.version}") String a) { System.out.println("bean1(" + a + ")"); return new Bean1(); } @Bean public Bean1 bean1(@Value("${java.class.version}") String a, @Value("${JAVA_HOME}") String b) { System.out.println("bean1(" + a + ", " + b + ")"); return new Bean1(); }
如果有重載方法,參數(shù)中需要注入的值越多,優(yōu)先級越高。
注意點3
@Configuration不能隨便刪除,因為默認(rèn)會為標(biāo)注的類生成代理, 其目的是保證 @Bean 方法相互調(diào)用時, 仍然能保證其單例特性
注意點4
@Configuration 中如果含有 BeanFactory 后處理器, 則實例工廠方法會導(dǎo)致 MyConfig 提前創(chuàng)建, 造成其依賴注入失敗,解決方法是該用靜態(tài)工廠方法或直接為 @Bean 的方法參數(shù)依賴注入, 針對 MapperScanner 可以改用注解方式
springboot自動配置
@SpringBootApplication 是一個組合注解,由 @ComponentScan、@EnableAutoConfiguration 和 @SpringBootConfiguration 組成:
@SpringBootConfiguration 與普通 @Configuration 相比,唯一區(qū)別是前者要求整個 app 中只出現(xiàn)一次,因為要根據(jù)它斷定主配置類,根據(jù)主配置類才能找到整個程序的入口
@ComponentScan:組件掃描
excludeFilters - 用來在組件掃描時進(jìn)行排除,也會排除自動配置類
@EnableAutoConfiguration 也是一個組合注解,由下面注解組成
@AutoConfigurationPackage – 用來記住掃描的起始包,也就是記錄被它標(biāo)注的類所在的包
@Import(AutoConfigurationImportSelector.class) 用來加載 META-INF/spring.factories 中的自動配置類(自動配置類就是如果主配置類沒有配置的就會去用自動配置類)
為什么不使用 @Import 直接引入自動配置類
有兩個原因:
- 讓主配置類和自動配置類變成了強耦合,主配置類不應(yīng)該知道有哪些從屬配置
- 直接用 @Import(自動配置類.class),引入的配置解析優(yōu)先級較高,自動配置類的解析應(yīng)該在主配置沒提供時作為默認(rèn)配置
因此,采用了 @Import(AutoConfigurationImportSelector.class)
- 由
AutoConfigurationImportSelector.class
去讀取META-INF/spring.factories
中的自動配置類,實現(xiàn)了弱耦合。 - 另外
AutoConfigurationImportSelector.class
實現(xiàn)了 DeferredImportSelector 接口,讓自動配置的解析晚于主配置的解析
到此這篇關(guān)于Springboot自動配置與@Configuration配置類詳解的文章就介紹到這了,更多相關(guān)Springboot自動配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IDEA生成項目后出現(xiàn)的iml和idea文件問題
這篇文章主要介紹了IDEA生成項目后出現(xiàn)的iml和idea文件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08Java中final,finally,finalize?有什么區(qū)別
這篇文章主要給大家分享的是?Java中final,finally,finalize?到底有什么區(qū)別,文章圍繞final,finally,finalize的相關(guān)資料展開詳細(xì)內(nèi)容,具有一定的參考的價值,需要的朋友可以參考一下2021-11-11詳解Java使用sqlite 數(shù)據(jù)庫如何生成db文件
這篇文章主要介紹了詳解Java 操作sqllite 數(shù)據(jù)庫如何生成db文件的相關(guān)資料,需要的朋友可以參考下2017-07-07