spring @Resource @Autowired @qualifier

spring不但支持自己定义的@Autowired注解,还支持几个由JSR-250规范定义的注解,它们分别是@Resource、

@PostConstruct以及@PreDestroy。

一.@Resource
  @Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自动注入

罢了。@Resource有两个属性是比较重要的,分是name和type,Spring将@Resource注解的name属性解析为bean的名字

,而type属性则解析为bean的类型。所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使

用byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略。
  @Resource装配顺序
  1. 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常
  2. 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常
  3. 如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常
  4. 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始

类型进行匹配,如果匹配则自动装配;

二.@Autowired 与@Resource的区别:
1、 @Autowired与@Resource都可以用来装配bean. 都可以写在字段上,或写在setter方法上。

2、 @Autowired默认按类型装配(这个注解是属业spring的),默认情况下必须要求依赖对象必须存在,如果要允许

null值,可以设置它的required属性为false,如:@Autowired(required=false) ,如果我们想使用名称装配可以结

合@Qualifier注解进行使用,如下:

@Autowired
@Qualifier("baseDao")
private BaseDao baseDao;

如果直接使用

@Autowired
private BaseDao baseDao;

那么其默认的beanName为baseDaoImpl(实现类名字,开头小写);
@Resource 默认的name也是一样的;
其中IDEA可以识别标注的name存不存在;(编译检查)
所以在接口只要一个实现类的情况下,可以直接使用@Autowired

3、@Resource(这个注解属于J2EE的),默认按照名称进行装配,名称可以通过name属性进行指定,如果没有指定

name属性,当注解写在字段上时,默认取字段名进行安装名称查找,如果注解写在setter方法上默认取属性名进行装

配。当找不到与名称匹配的bean时才按照类型进行装配。但是需要注意的是,如果name属性一旦指定,就只会按照名

称进行装配。
注:默认情况可能会2次查找,性能会低些;

三 @qualifier作用
1.限定匹配bean
2.也支持逻辑限定,即可以修饰注解,如@LoadBalanced
详见:https://www.cnblogs.com/fangshixiang/p/11532717.html

四.@Primary :优先考虑注入的类,比如两个类继承了同一个接口,然后注入的时候是以接口名的形式注入到另一个

类中的。 这个时候会报一下错误:

Unsatisfied dependency expressed through field ‘animal’; nested exception is

org.springframework.beans.factory.NoUniqueBeanDefinitionException: No qualifying bean of type

‘com.hbr.three.Animal’ available: expected single matching bean but found 2: dog,panda

也就是说,animal接口没有唯一的bean定义。本来想找一个bean的,可是却发现了两个,dog和panda. 然后就不知道

带注入哪个实例了,然后就报错了。

被注入的类是这样的:

@Component
public class DIclass {

@Autowired
private  Animal animal;

public void eat(){
    animal.eat();
}

}
然后dog和panda实现了animal的接口。

测试里面是这样的:

AnnotationConfigApplicationContext app = new AnnotationConfigApplicationContext(Configurate.class);
DIclass bean = (DIclass)app.getBean(“DIclass”);
bean.eat();
这里注意,包扫描的beanname是类名一致,没有首字母小写的,不要和@bean注解默认的名字搞混了。
所以这个时候 @Primary 注解就发挥作用了,它会优先考虑有这个注解的类。

参考:https://www.cnblogs.com/fengli9998/p/7472247.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值