設定類別(@Configuration下的這個類別)其實相當於一個工廠, 標註@ Bean 註記的方法相當於工廠方法
考慮有如下例子:
@Configuration // 注意点1: 配置类其实相当于一个工厂, 标注 @Bean 注解的方法相当于工厂方法 static class MyConfig { @Bean public Bean1 bean1() { System.out.println("bean1()"); return new Bean1(); }
#將來如果要產生一個bean1的實例,首先要找到一個叫myConfig的bean(是工廠),再呼叫這個工廠裡面叫"bean1"的方法,生成bean1物件。
對於沒有static修飾的@Bean工廠方法,叫做實例工廠,需要先把配置類別myConfig實例創建出來;有static修飾的是靜態方法,只需要拿到myConfig的類別對象,然後直接.方法就行。
@Bean 不支援方法重載, 如果有多個重載方法, 僅有一個能入選為工廠方法
@Configuration @MapperScan("aaa") // 注意点1: 配置类其实相当于一个工厂, 标注 @Bean 注解的方法相当于工厂方法 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(); }
如果有重載方法,參數中需要注入的值越多,優先權越高。
@Configuration不能隨便刪除,因為預設會為標註的類別產生代理, 其目的是保證@Bean 方法相互調用時, 仍然能保證其單例特性
@Configuration 中如果含有BeanFactory 後處理器, 則實例工廠方法會導致MyConfig 提前創建, 造成其依賴注入失敗,解決方法是該用靜態工廠方法或直接為@Bean 的方法參數依賴注入, 針對MapperScanner 可以改用註解方式
@SpringBootApplication 是一個組合註解,由@ComponentScan、@EnableAutoConfiguration 和@SpringBoot:#Configuration 組成
##@SpringBootConfiguration 與普通@Configuration 相比,唯一區別是前者要求整個app 中只出現一次,因為要根據它斷定主配置類,根據主配置類才能找到整個程式的入口@ComponentScan:元件掃描excludeFilters - 用來在元件掃描時排除,也會排除自動配置類別@EnableAutoConfiguration 也是一個組合註解,由下方註解組成#@AutoConfigurationPackage – 用來記住掃描的起始包,也就是記錄被它標註的類別所在的套件@Import(AutoConfigurationImportSelector.class) 用來載入META-INF/spring.factories中的自動配置類別(自動配置類別就是如果主配置類別沒有配置的就會去用自動配置類別)為什麼不使用@Import 直接引入自動配置類別#有兩個原因:@Import(AutoConfigurationImportSelector.class)
AutoConfigurationImportSelector.class 去讀取
#META-INF/spring.factories 中的自動配置類,實現了弱耦合。
AutoConfigurationImportSelector.class 實作了 DeferredImportSelector 接口,讓自動配置的解析晚於主配置的解析
以上是Springboot自動配置與@Configuration配置類別實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!