@Resource注解
@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是變量名
錯誤示例:
@Resourceprivate String bucketName;@Resourceprivate 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進行裝配,找不到則拋出異常
總結
以上是生活随笔為你收集整理的@Resource注解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: NLP【07】transformer原理
- 下一篇: 简支梁挠度计算公式推导_简支梁的最大挠度