关于@autoWire与@resource的区别

首先@resource的范围比@autoWire的大

  1. 首先根据类型找到所有可以满足条件的bean
  2. 判断bean长度,如果没有,则根据@autowired中的required属性进行判断是否抛出异常(默认为true)
  3. 如果多于一个,则尝试寻找最优的那一个,如果最优的未找到,则抛出异常
  4. 如果只有一个,则直接使用此bean

如果@autoWire是在setter方法上标注的话,默认是按照参数名称而不是setter后面的属性名称进行注入,如果没有这个参数名称的话就按byType,以下是按tx1参数名称注入

public void setTx2(TxInterface tx1) {this.tx2 = tx1;}

如果autoWire标注在字段上面,则直接使用字段名称。进行查找,如

@autowire
private String username;

如果是按照@resource标注的话先会根据name进行匹配,如果匹配不到在退化成byType

  1. 获取element的名称,判断beanFactory是否存在此name的bean
  2. 如果存在,则直接使用此name进行查询
  3. 否则退化到默认的autowire查找方式
  4. 这里说是element的名称,因为它的来源有2个地方。一是在resouce注解中配置的name属性,第二就是setter名称或者是field名称(取决于@Resource的配置地点),这里说的是setter名称,而不是属性名称,这就是需要注意的地方

值得注意的是,如果在使用resource时,根据resource的name找到了bean,但该bean并不是所需要的bean类型,则就要报类型不 匹配错误了。即spring在查找时,并没有保证类型判断,即你配置一个name的tx2的bean,但该类型即为TxInterface2而不是 TxInterface,则spring在后期直接报异常,而不会fallback了。但Autowired注解则不会产生这种情况,因为它只会从满足 type的情况中的bean中查找

时间: 2024-10-05 05:02:00

关于@autoWire与@resource的区别的相关文章

@Autowired 与@Resource的区别(详细)

参考博文: http://www.cnblogs.com/happyyang/articles/3553687.html http://blog.csdn.net/revent/article/details/49203619 http://blog.csdn.net/ad921012/article/details/49679745 spring不但支持自己定义的@Autowired注解,还支持几个由JSR-250规范定义的注解,它们分别是@Resource.@PostConstruct以及@

Spring 注释 @Autowired 和@Resource 的区别

Spring 注释 @Autowired 和@Resource 的区别 一. @Autowired和@Resource都可以用来装配bean,都可以写在字段上,或者方法上. 二. @Autowired属于Spring的:@Resource为JSR-250标准的注释,属于J2EE的. 三. @Autowired默认按类型装配,默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false,例如:@Autowired(required=false) ,如果我们

Spring基础系列15 -- @Autowired和@Resource的区别

@Autowired和@Resource的区别 转载:http://www.cnblogs.com/leiOOlei/p/3713779.html 一. @Autowired和@Resource都可以用来装配bean,都可以写在字段上,或者方法上. 二. @Autowired属于Spring的:@Resource为JSR-250标准的注释,属于J2EE的. 三. @Autowired默认按类型装配,默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为fal

Autowired和Resource的区别.

Autowired和Resource的区别. 标签(空格分隔): Spring @Resource 默认按照名称来装配注入, 只有当找不到与匹配的bean才会按照类型来装配注入. 如果同时指定了name和type, 则从Spring上下文忠找到唯一匹配的bean进行装配, 找不到则抛出异常. 如果指定了name, 则从上下文中查找名称匹配的bean进行装配, 找不到则抛出异常. 如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配, 找不到或者找到多个都会异常报错. 如果既没有指定

打xap包的时候content和resource的区别

参考自晴天猪这篇文章. 项目打包的时候,resource和content的都可以被打包到xap里,区别只是放到dll里面还是外面的问题. 我们通过程序Bin目录生成XAP文件后缀改成zip,解压后来分析二者的区别: ①当生成操作为Resource时,图片与编译后的程序一同存储在DLL文件中. ②当生成操作为内容(Content)时,图片存储在DLL文件的外部,但是依旧还早XAP文件中. 二者的使用情境该如何选择呢?微软建议使用在应用程序中将生成操作设置为”内容“,这样可以限制二进制文件(DLL)

关于@Autowired和@Resource注解区别

区分一下@Autowired和@Resource两个注解的区别: 1.@Autowired默认按照byType方式进行bean匹配,@Resource默认按照byName方式进行bean匹配 2.@Autowired是Spring的注解,@Resource是J2EE的注解,这个看一下导入注解的时候这两个注解的包名就一清二楚了 Spring属于第三方的,J2EE是Java自己的东西,因此,建议使用@Resource注解,以减少代码和Spring之间的耦合. @Service("StudentSer

@autowired和@resource的区别

@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自动注入罢了.@Resource有两个属性是比较重要的,分是name和type,Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型.所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略.如果既不指定name也不指定type属性,这时将通过反射

@Autowired与@Resource的区别

1.@Autowired与@Resource都可以用来装配bean. 都可以写在字段上,或写在setter方法上. 2.@Autowired默认按类型装配(这个注解是属业spring的),默认情况下必须要求依赖对象必须存在,如果要允许null 值,可以设置它的required属性为false,如:@Autowired(required=false) ,如果我们想使用名称装配可以结合@Qualifier注解进行使用,如下: Java代码   @Autowired() @Qualifier("bas

@Autowired 与@Resource的区别

@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自动注入罢了.@Resource有两个属性是比较重要的,分是name和type,Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型.所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略.如果既不指定name也不指定type属性,这时将通过反射