注解之----@Resource


原文鏈接:https://blog.csdn.net/weixin_38237873/article/details/83650429

 

@Resource和@Autowired注解都是用來實現依賴注入的。只是@AutoWried按by type自動注入,而@Resource默認按byName自動注入。

@Resource有兩個重要屬性,分別是name和type

spring將name屬性解析為bean的名字,而type屬性則被解析為bean的類型。所以如果使用name屬性,則使用byName的自動注入策略,如果使用type屬性則使用byType的自動注入策略。如果都沒有指定,則通過反射機制使用byName自動注入策略。

@Resource依賴注入時查找bean的規則:(以用在field上為例)

1. 既不指定name屬性,也不指定type屬性,則自動按byName方式進行查找。如果沒有找到符合的bean,則回退為一個原始類型進行查找,如果找到就注入。

此時name是變量名

錯誤示例:

@Resource
private String bucketName;
@Resource
private String styleName;
此時的name值是配置bean里的name屬性指定的值,而不是id的值

<bean id="bucketName " class="java.lang.String">
<constructor-arg value="${oos.bucketName}"/>
</bean>
<!-- 圖片樣式名 -->
<bean id="styleName " class="java.lang.String">
<constructor-arg value="${oos.styleName}"/>
</bean>
這里為什么要重新理解,是因為之前我一直認為對應的是配置文件的id屬性的值,直到在配置上面兩個String類型的bean的時候,居然會報錯,如下: No qualifying bean of type [java.lang.String] is defined: expected single matching bean but found 2: bucketName,styleName 這是因為spring會去找bean元素里name屬性值和變量名一致的bean,但是因為都沒有指定name屬性,所以找不到然后就按照原始類型String去查找,結果一下找到了兩個,所以就報錯。

2. 只是指定了@Resource注解的name,則按name后的名字去bean元素里查找有與之相等的name屬性的bean。

正確示例

@Resource(name="bucket")
private String bucketName;
@Resource(name="style")
private String styleName;
<bean name="bucket" class="java.lang.String">
<constructor-arg value="${oos.bucketName}"/>
</bean>
<!-- 圖片樣式名 -->
<bean name="style" class="java.lang.String">
<constructor-arg value="${oos.styleName}"/>
</bean>
3. 只指定@Resource注解的type屬性,則從上下文中找到類型匹配的唯一bean進行裝配,找不到或者找到多個,都會拋出異常

4. 既指定了@Resource的name屬性又指定了type,則從Spring上下文中找到唯一匹配的bean進行裝配,找不到則拋出異常



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM