Java之Spring注解配置bean實例代碼解析
前面幾篇均是使用xml配置bean,如果有上百個bean,這是不可想象的。故而,請使用注解配置bean !!!
【1】注解類別
@Component : 基本注解, 標識了一個受 Spring(點擊這里可以下載《Spring應(yīng)用開發(fā)完全手冊》) 管理的組件
@Repository : 標識持久層組件
@Service : 標識服務(wù)層(業(yè)務(wù)層)組件
@Controller : 標識表現(xiàn)層組件
Spring 能夠從 classpath 下自動掃描, 偵測和實例化具有特定注解的組件。
對于掃描到的組件, Spring 有默認的命名策略: 使用非限定類名, 第一個字母小寫. 也可以在注解中通過 value 屬性值標識組件的名稱
【2】context:component-scan
當在組件類上使用了特定的注解之后, 還需要在 Spring 的配置文件中聲明 <context:component-scan/> :base-package 屬性指定一個需要掃描的基類包,Spring 容器將會掃描這個基類包里及其子包中的所有類。
當需要掃描多個包時, 可以使用逗號分隔,如果僅希望掃描特定的類而非基包下的所有類,可使用 resource-pattern 屬性過濾特定的類。示例:
<context:component-scan base-package="com.web.annotation" resource-pattern="repository/*.class" use-default-filters="true"> <context:include-filter> 子節(jié)點表示要包含的目標類 <context:exclude-filter> 子節(jié)點表示要排除在外的目標類 <context:component-scan> 下可以擁有若干個 <context:include-filter> 和 <context:exclude-filter> 子節(jié)點
一個復(fù)雜的<context:component-scan/>
如下配置將只掃描repository下的包:resource-pattern="repository/*.class" 默認fileter(use-default-filters="true")將掃描所有注解組件,若想使用 include-filter等,則將其改為false. <context:component-scan base-package="com.web.annotation" resource-pattern="repository/*.class" use-default-filters="true"> <!-- 只包含Repository注解 ,其他不行--> <!-- <context:include-filter type="annotation" expression="org.springframework.stereotype.Repository"/>--> <!-- 不包含Repository注解 ,其他可以--> <!-- <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Repository"/>--> <!-- 只包含Repository接口及其實現(xiàn)類 ,其他不行--> <!-- <context:include-filter type="assignable" expression="com.web.annotation.repository.UserRepository"/>--> <!-- 不包含Repository接口及其實現(xiàn)類 ,其他可以--> <!-- <context:exclude-filter type="assignable" expression="com.web.annotation.repository.UserRepository"/>--> </context:component-scan>
【3】代碼中引用其他bean,簡單示例如下:
@Resource(name="userRepository")
private UserRepository repository;
public void add(){
System.out.println("UserService add...");
repository.save();
}
引用其他bean有如下幾種方式:
@Autowired 和 @Resource 、@Inject
【4】使用 @Autowired 自動裝配 Bean
@Autowired 注解自動裝配具有兼容類型的單個 Bean屬性,構(gòu)造器, 普通字段(即使是非 public), 一切具有參數(shù)的方法都可以應(yīng)用@Authwired 注解
默認按類型匹配,若一個類型多個實現(xiàn),將會自動查詢注解定義的名字,先匹配。若實現(xiàn)類注解都沒有定義名字,將會拋出異常?。?br />
1)默認情況下, 所有使用 @Authwired 注解的屬性都需要被設(shè)置。
當 Spring 找不到匹配的 Bean 裝配屬性時, 會拋出異常, 若某一屬性允許不被設(shè)置, 可以設(shè)置 @Authwired 注解的 required 屬性為 false。
2)默認情況下, 當 IOC 容器里存在多個類型兼容的 Bean 時, 通過類型的自動裝配將無法工作。此時可以在 @Qualifier 注解里提供 Bean 的名稱. Spring 允許對方法的入?yún)俗?@Qualifiter 已指定注入 Bean 的名稱。
3)@Authwired 注解也可以應(yīng)用在數(shù)組類型的屬性上, 此時 Spring 將會把所有匹配的 Bean 進行自動裝配。
4)@Authwired 注解也可以應(yīng)用在集合屬性上, 此時 Spring 讀取該集合的類型信息, 然后自動裝配所有與之兼容的 Bean。
5)@Authwired 注解用在 java.util.Map 上時, 若該 Map 的鍵值為 String, 那么 Spring 將自動裝配與之 Map 值類型兼容的 Bean, 此時 Bean 的名稱作為鍵值。
【5】使用 @Resource 自動裝配 Bean
@Resource 注解要求提供一個 Bean 名稱的屬性,若該屬性為空,則自動采用標注處的變量或方法名作為 Bean 的名稱
我是最喜歡使用這個注解的,寫上字段值@Resource(value="userService"),簡單方便又省心。不用擔心一個類型多個實現(xiàn),而且不用額外加@Qualifier 去進行精確匹配。
【6】注解獲取bean,并使用方法,如:
@Repository(value="bookShopDAO")
public class BookShopDAOImpl implements BookShopDAO {
}
類型為實現(xiàn)類型
@Resource(name="bookShopDAO") BookShopDAOImpl bookShopDAO;
將可以使用 BookShopDAOImpl 的所有方法 !!
類型為接口類型
@Resource(name="bookShopDAO")
BookShopDAO bookShopDAO;
//此時用到了多態(tài)
將只能使用 BookShopDAO中定義 的所有方法 ?。?,不能使用實現(xiàn)類自定義的方法
總結(jié)
本文關(guān)于Spring注解配置bean實例代碼解析的內(nèi)容就到這里了,希望對大家有所幫助。有興趣的朋友可以參閱:Javabean和map相互轉(zhuǎn)化方法代碼示例,java中javaBean與Bean的深入理解,javaBean的基礎(chǔ)知識及常見亂碼解決方法等。感謝大家對腳本之家的支持!
相關(guān)文章
基于Jpa中ManyToMany和OneToMany的雙向控制
這篇文章主要介紹了Jpa中ManyToMany和OneToMany的雙向控制,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
簡單談?wù)凧ava中String類型的參數(shù)傳遞問題
這篇文章主要介紹了簡單談?wù)凧ava中String類型的參數(shù)傳遞問題的相關(guān)資料,需要的朋友可以參考下2015-12-12
java_時間戳與Date_相互轉(zhuǎn)化的實現(xiàn)代碼
本篇文章是對java_時間戳與Date_相互轉(zhuǎn)化的實現(xiàn)代碼進行了詳細的分析介紹,需要的朋友參考下如下。2016-11-11
如何使用Mockito調(diào)用靜態(tài)方法和void方法
這篇文章主要介紹了如何使用Mockito調(diào)用靜態(tài)方法和void方法的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07

