zoukankan      html  css  js  c++  java
  • 用@Resource注解完成属性装配

    使用Field注入(用于注解方式):注入依赖对象可以采用手工装配或者手工自动装配。在实际应用中建议使用手工装配,因为自动装配会产生未知情况,开发人员无法预见最终的装配结果。

    依赖注入—手工装配

    手工装配依赖对象,在这种方式中又有两种编程方式。

    1.在xml配置文件中,通过bean节点配置,如:

    1 <bean id="orderService" class="cn.itcast.service.OrderServiceBean">
    2     //构造器注入
    3     <constructor-arg index="0" type="java.lang.String" value="xxx"/>
    4     //属setter方法注入
    5     <property name="name" value="zhao"/>
    6 </bean>

    2.在java代码中使用@Autowired或者@Resource注解方式进行装配。但我们需要在xml配置文件中配置一下信息

    1  <beans Xmlns="http://www.springframework.org/schema/beans"
    2              Xmlns="http://www.w3.org/2001/XMLSchema-instance"
    3              Xmlns:context="http://www.springframework.org/schema/context"
    4              Xsi:schemaLocation="http://www.springframework.org/schema/beans
    5                          http://www.springframework.org/schema/context
    6                          http://www.springframework.org/schema/context/spring-context-2.5xsd">
    7 </beans>  

    这个配置隐式注册了多个对注释进行解析处理的处理器:
    AutowiredAnnotationBeanPostProcessor,CommonAnnotationBeanPostProcessor

    PersistenceAnnotationBeanProcessor,RequiredAnnotationBeanPostProcessor

    3.区别

    在java代码中使用@Autowired或@Resource注解方式进行装配。这两个注解的区别是@Autowired默认按类型装配@Resource默认按名称进行装配,当找不到与名称匹配的bean才会按类型装配

    1 @Autowired
    2 private PersonDao personDao;//用于字段上
    3 @Autowired
    4 public void setOrderDao(OrderDao orderDao){
    5        this.orderDao = orderDao; //用于属性的setter方法上      
    6 }

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

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

    @Resource注解和@Autowired一样,可以标注在字段或者属性的setter方法上,但它默认按名称装配。名称可以通过@Resource的name属性指定;如果没有指定name属性,当注解标注在字段上,即默认字段的名称作为bean名称寻找依赖对象;当注解标注在属性setter方法上,即默认取属性名作为bean名称寻找依赖对象

    @Resource(name="personDaoBean")
    private PersonDao personDao;

    注:如果没有指定name属性,并且按照默认的名称仍找不到对象时,@Resource注解会回退到按类型装配。但一旦指定了name属性,就只能按名称装配了。

  • 相关阅读:
    几种常用设计模式的白话版
    VS调试本地IIS的代码
    关于Oracle全局临时表 Global Temporary Tables 的使用
    【转】SQL Server查询数据库所有存储过程、触发器、索引信息SQL分享
    【转】Uncaught TypeError: Cannot set property ' ' of null 错误解决
    SqlServer数据库基础知识整理(不断更新~)
    Tools快捷键收集
    SqlServer的Merge Into用法
    wamp安装使用
    验证码识别
  • 原文地址:https://www.cnblogs.com/ckysea/p/4536768.html
Copyright © 2011-2022 走看看