详细解析@Resource和@Autowired的区别 , 以及@Qualifier的作用
(41) (0)
首先 .
@Resource是javax.annotation 包中的注解类 , 是jdk中封装的 .
@AutoWired是spring的中注解,依赖于spring上下文.
相同点:
@Resource 和 @Autowired 都可以用在类中的field 或者function 上 , 在类初始化的时候 , 自动为field 赋值 , 自动为function注入参数并且执行该方法(不仅仅局限于set方法) .
不同点:
1. @Autowired 写在构造函数上,为构造器注入参数 , @Resource不能构造函数上.
2. @Autowired是根据注入类的类型来寻找bean的 , 如果同一个Type的类注入了多个id(或者name) 不一样的bean , 那么用@Autowired就无法准确的找到是哪个bean了, 这个时候就会抛出一个异常. 如果放在构造函数上 , 那么spring默认会使用该带参的构造器初始化类 , 当autowired传入required=false 时 , 如果初始化时没有找到注入的bean , 且该bean仍然有写空参的构造函数 , 则spring会自动调用空参的构造函数初始化 , 但是如果没有写空参构造函数 , 在会抛出异常.
3. @Resource分两种情况 :
- 在不传参数或者传入空参的情况下 , @Resource默认根据注入bean的字段名来寻找bean (若放在function上 , 如果该function为set方法, 则bean名称解析为set对应的字段名 , 如果不是set方法 , 则bean解析为function的方法名) , 如果找不到 , 在根据类型来寻找对应的bean, 如果还找不到 , 抛出异常 , 如果找不到与字段名相匹配的bean , 但是类型匹配的却有多个 , 也抛出异常 ;
- 在传入确定参数的情况下 , @Resouce或根据传入的name值来寻找这个名称的bean , 如果找不到则抛出异常 , 或者根据type值来寻找这个类型的bean , 也可以同时指定name和type.
@Qualifier 可以写在field 或者function传入参数的参数类型前面 , 用来指定注入bean的名称 ,如果不指定value, 那么默认是空名称, 也是可以编译通过的 , 但是无法匹配到对应的bean (以两个同一interface的实现注入不同名称的bean来测试 , 如果本身只有一个对应的bean , 或者仅仅通过@Resource 或 @Autowired就可以找到对应的bean , 就无法测试出来@Qualifier的效果了 ) ,所以一般情况下 , 使用@Qualifier都需要传入value参数 , 指定bean的名称 ,
最后注意一点 , @Resource虽然是JDK中的注解类 , 但是jdk中并没有具体的处理方式 , 需要依赖于其他框架或者工具才能实现具体功能 , 如果不加载spring容器 , 单独使用@Resource注解 , 是没有任何作用的.
下面是测试用的代码 , 很简单的例子 , 感兴趣的朋友 , 可以自己改一改userService来测试一下各种情况 .
beans:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<context:annotation-config/>
<context:component-scan base-package="com.pindao.six" />
</beans>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
interface
public interface UserDao {
}
- 1
- 2
- 3
- 4
实现:
@Component("userDao")
public class UserDaoImpl implements UserDao {
private int daoId = 1;
@Override
public String toString() {
return "UserDaoImpl{" +
"daoId=" + daoId +
'}';
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
@Component("userDao2")
public class UserDaoImpl2 implements UserDao {
private int daoId = 2;
@Override
public String toString() {
return "UserDaoImpl{" +
"daoId=" + daoId +
'}';
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
service
@Component
public class UserService {
private UserDao userDao;
public UserService(){
System.out.println("this is constructor");
}
// @Autowired(required = false)
public UserService(UserDao userDao){
System.out.println("this is constructor with paramater");
this.userDao = userDao;
}
public void getDao(){
System.out.println(this);
System.out.println(userDao);
}
public UserDao getUserDao() {
return userDao;
}
@Autowired
public void setUserDao(@Qualifier("userDao2") UserDao userDao) {
this.userDao = userDao;
}
public void userDao2(UserDao userDao){
System.out.println("this is normal mothed");
this.userDao = userDao;
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
jUnit测试:
public class UserServiceTest {
@Test
public void testGetDao() throws Exception {
ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
System.out.println("----");
UserService userService = (UserService)context.getBean("userService");
userService.getDao();
}
}
详细解析@Resource和@Autowired的区别 , 以及@Qualifier的作用的更多相关文章
- 详细解析 HTTP 与 HTTPS 的区别
详细解析 HTTP 与 HTTPS 的区别 超文本传输协议HTTP协议被用于在Web浏览器和网站服务器之间传递信息,HTTP协议以明文方式发送内容,不提供任何方式的数据加密,如果攻击者截取了Web浏览 ...
- 【Java面试】@Resource 和 @Autowired 的区别
Hi,大家好,我是Mic. 一个工作2年的粉丝,问我一个Spring里面的问题. 希望我能从不同的视角去分析,然后碾压面试官. 这个问题是: "@Resource和@Autowired&qu ...
- Spring注解@Resource和@Autowired的区别
@Resource和@Autowired都是用来做bean的依赖注入的,两者都可以写在字段和setter方法上. java为我们提供了 javax.annotation.Resource这个注解. s ...
- 简析@Resource 和 @Autowired的区别
@Autowird @Autowird 属于spring框架,默认使用类型(byType)进行注入,例如下面代码: @Autowired public IUserService userService ...
- @Resource和@Autowired的区别
@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自动注入罢了.@Resource有两个属性是比较重要的,分 ...
- spring @Resource和@Autowired的区别
@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自动注入罢了.@Resource有两个属性是比较重要的,分 ...
- @Resource、@Autowired跟default-autowire区别联系
@Resource.@Autowired和default-autowire区别联系 今天看了一工程,里面既有default-autowire,又有@Autowired,还有@Resource.我就不明 ...
- @Resource、@Autowired、@Qualifier 区别(表格显示)
@Resource.@Autowired.@Qualifier 区别(表格显示) 区别项 @Resource @Autowired @Qualifier 谁提供的 jdk提供,包是javax.anno ...
- @Resource或者@Autowired作用/Spring中@Autowired注解、@Resource注解的区别
@Resource或者@Autowired作用不用写set get就能注入,当然,前提是你已经开启了注解功能. spring不但支持自己定义的@Autowired注解,还支持几个由JSR-250规范定 ...
随机推荐
- flask中的CBV和FBV
flask中CBV使用 from flask import Flask, views app = Flask(__name__) class Login(views.MethodView): meth ...
- JS数组去重的十种方法(转载)
重点:博客原文出自http://www.cnblogs.com/yuanbo88/p/7345331.html.我只是想给自己做个笔记.感谢敲代码的怪蜀黍做的贡献. Methods 1: 思路:定义一 ...
- cefsharp作为采集工具(学习笔记)
cefsharp(webkit内核)浏览器替代webbrowser用来采集页面数据. 需要在页面form加载完毕,用异步方式自动获取sourcecode. 由于国内cefsharp的资料相对比较少,在 ...
- 云监控自定义HTTP状态码说明
您在使用站点监控时,返回的6XX状态码均为云监控自定义HTTP状态码,具体含义如下表所示: 状态码 含义 备注 610 HTTP连接超时 监测点探测您的网站时出现连接超 ...
- JSP/Servlet开发——第二章 JSP数据交互(二)
1. JSP 内置对象 application: ●application 对象类似于系统的 "全局变量", 用于同一个应用内的所有用户之问的数据共享: ●application对 ...
- 23种java设计模式之装饰者模式及动态代理
设计模式不管对于何种语言都是存在的,这里介绍的是java的模式 装饰者模式是在二次开发中应用比较多的一款模式,当然了用反射也是可以实现的,今天介绍的是装饰模式,有兴趣的朋友可以自己去了解一下反射是怎么 ...
- 【ppp-chap,pap,mp,mp-group】
PPP链路端口验证(单){ PAP(明文): 主验证方: {local-user user_name:配置本地用户; password {simple||cipher}:配置验证密码; service ...
- Angular : 响应式编程, 组件间通信, 表单
Angular 响应式编程相关 ------------------------------------------------------------------------------------ ...
- 使用SQLite删除Mac OS X 中launchpad里的快捷方式
一般情况下,从App Store安装的应用程序,如果应用删除,那么launchpad里对应的图标会一起删除了. 而对于不是通过App Store安装的应用程序,删除应用程序,Launchpad中很可能 ...
- python 装饰器 (多个装饰器装饰一个函数---装饰器前套一个函数)
#带参数的装饰器 #500个函数 # import time # FLAGE = False # def timmer_out(flag): # def timmer(func): # def inn ...