@Autowire默认按照类型装配,默认情况下它要求依赖对象必须存在如果允许为null,可以设置它required属性为false,如果我们想使用按照名称装配,可以结合@Qualifier注解一起使用;
@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而 @Resource默认按 byName自动注入罢了。
@Resource有两个属性是比较重要的,分是name和type,Spring将
@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略。
如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略。
@Resource装配顺序
- 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常
- 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常
- 如果指定了type,则从上下文中找到类型(class)匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常(2,3两点说白了就是名称找bean的id,类型找bean的class)
- 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配;
另外,由于@Autowired是按照类型进行装配的 所以可以用集合去接收。
一下一个小示例大体展示名称装配与类型装配。
举个简单的例子:
//对象Bean 依赖对象 Bean1
public class Bean {
private Bean1 bean1;
public Bean1 getBean1() {
return bean1;
}
public void setBean1(Bean1 bean1) {
this.bean1 = bean1;
}
}
Spring配置文件里的内容:
<!-- 第一种写法 start-->
<!-- 类型注入 -->
<bean id="bean" class="com.zcl.spring.Bean">
<!-- 名称注入 -->
<property name="bean1" ref="bean1"/>
</bean>
<!-- 第一种写法 end -->
<!-- 第二种写法 start -->
<!-- 类型注入-->
<bean id="bean" class="com.zcl.spring.Bean"/>
<bean id="bean1" class="com.zcl.spring.Bean1"/>
<!-- 第二种写法 end -->