zoukankan      html  css  js  c++  java
  • Spring 注解 @Resource和@Autowired

    摘要: 在做Spring注解时,查找了一些 @Resource和@Autowired的资料,对这两者做了总结和对比

     @Resource和@Autowired两者都是做bean的注入使用。

    其实@Resource并不是Spring的注解,包是javax.annotation.Resource 需要导入。但是Spring支持该注解的注入。

    共同点:两者都可以写在字段和setter方法上。两者如果都写在字段上,就不需要写在setter方法。

    不同点如下:

    先来说一说@Autowired

        @Autowired为Spring提供的注解,

        需导入Package:org.springframework.beans.factory.annotation.Autowired;

        只按照byType 注入。

    @Autowired 
    private UserDao userDao;//用于字段上
    
    @Autowired
    public void setUserDao(UserDao userDao) {//用于属性的setter方法上
      this.userDao= userDao;
    }

        @Autowired注解是按类型装配依赖对象,默认情况下它要求依赖对象必须存在,如果允许null值,可以设置它required属性为false。如果我们想使用按名称装配,可以结合@Qualifier注解一起使用。如下:

    @Autowired  
    @Qualifier("userDao") private PersonDao personDao;

     再说说@Resource

    @Resource默认按 byName 自动注入,由J2EE提供。

        需导入Package:  javax.annotation.Resource

        @Resource有两个中重要的属性:name和type ,而Spring将@Resource注解的name属性解析为bean的

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

        type属性时则使用 byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略。

    @Resource(name=“userDao”)
    private UserDao userDao;//用于字段上
    
    @Resource(name=“userDao”)
    public void setUserDao(UserDao userDao) {//用于属性的setter方法上
      this.userDao= userDao;
    }

        注:最好是将@Resource放在setter方法上。

        @Resource装配顺序 

      (1). 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常;

      (2). 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常;

      (3). 如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常;

      (4). 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配;

        @Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入。

  • 相关阅读:
    c++ 图解快速排序算法
    Shell脚本检测文件夹是否已被挂载的方法
    Linux使用mount挂载samba共享
    PHP使用字符串名称调用类的方法
    命令行查看端口号被进程占用
    Golang Clearing slice
    送给自己的程序员箴言
    Entity Framework6 with Visual Studio 2013 update3 for Oracle 11g
    深入浅出ASP.NET MVC5系列之一
    年终福利:调试.NET Framework源代码
  • 原文地址:https://www.cnblogs.com/sky-sql/p/6933835.html
Copyright © 2011-2022 走看看