Spring @Primary和@Qualifier注解原理解析
一 前言
本篇內(nèi)容主要是講解2個(gè)重要的注解使用方式和場(chǎng)景,@Primary,@Qualifier注解;其作用就是消除bean注入時(shí)的歧義,能夠讓spring容器知道加載哪個(gè)bean;
知識(shí)追尋者(Inheriting the spirit of open source, Spreading technology knowledge;)
二 實(shí)現(xiàn)方式
如下示例中使用被單接口Sheet, 實(shí)現(xiàn)類為SheetA , SHeetB ; 由于注入容器時(shí)都是 Sheet類型,會(huì)發(fā)生異常,此時(shí)就是使用@Primary或者@Qualifier對(duì)注入的bean進(jìn)行限制,即可實(shí)現(xiàn)正常注入;
2.1 被單接口
/** * @Author lsc * <p> 被單</p> */public interface Sheet { String getColor();}
2.2 被單實(shí)現(xiàn)類
實(shí)現(xiàn)類A
重寫(xiě)getColor()方法;輸出red
/** * @Author lsc * <p> </p> */public class SheetA implements Sheet { public String getColor() { return 'red'; }}
實(shí)現(xiàn)類B
重寫(xiě)getColor()方法;輸出pink
/** * @Author lsc * <p> </p> */public class SheetB implements Sheet { public String getColor() { return 'pink'; }}
2.3 配置類
@Configurationpublic class SheetConfig { @Bean public Sheet sheetA(){ return new SheetA(); } @Bean public Sheet sheetB(){ return new SheetB(); }}
2.4 測(cè)試類
/** * @Author lsc * <p> </p> */@RunWith(SpringJUnit4ClassRunner.class)//創(chuàng)建spring應(yīng)用上下文@ContextConfiguration(classes= {SheetConfig.class})//加載配置類public class SheetTest { @Autowired Sheet sheet; @Test public void sheetTest(){ // System.out.println(sheet.getColor()); }}
測(cè)試會(huì)報(bào)異常,原因是向spring容器注入了2個(gè)Sheet,無(wú)法區(qū)分是SheetA 還是 SheetB,所以會(huì)造成bean的歧義問(wèn)題;
Caused by: org.springframework.beans.factory.NoUniqueBeanDefinitionException:
解決辦法一
在注入的bean上添加@Primary注解;示例如下,此時(shí)向sheetB上添加@Primary注解,spring掃碼注入bean時(shí)優(yōu)先注入帶有@Primary注解的bean;測(cè)試輸出結(jié)果為pink
@Bean@Primarypublic Sheet sheetB(){return new SheetB();}
解決辦法二
注入bean時(shí)添加@Qualifier注解,限定注入的Bean;此時(shí)輸出就是red
@Qualifier('sheetA')//限定注入Bean ID@AutowiredSheet sheet;
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 使用css實(shí)現(xiàn)全兼容tooltip提示框2. div的offsetLeft與style.left區(qū)別3. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)4. Vue3使用JSX的方法實(shí)例(筆記自用)5. JavaScript數(shù)據(jù)類型對(duì)函數(shù)式編程的影響示例解析6. 詳解CSS偽元素的妙用單標(biāo)簽之美7. CSS代碼檢查工具stylelint的使用方法詳解8. 利用CSS3新特性創(chuàng)建透明邊框三角9. vue實(shí)現(xiàn)將自己網(wǎng)站(h5鏈接)分享到微信中形成小卡片的超詳細(xì)教程10. 不要在HTML中濫用div
