一、依赖注入--手工装配—注解方式

在java代码中使用@Autowired或@Resource注解方式进行装配的前提条件是:
  1、引入context命名空间
需要在xml配置文件中配置以下信息:

  <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-3.0.xsd

http://www.springframework.org/schema/context
          
http://www.springframework.org/schema/context/spring-context-3.0.xsd">

<context:annotation-config/>

</beans>

注意到:
    
在配置文件中添加context:annotation-config标签<context:annotation-config/>这个配置隐式注册了多个对注释进行解析处理的处理器:
                    
AutowiredAnnotationBeanPostProcessor,CommonAnnotationBeanPostProcessor,

PersistenceAnnotationBeanPostProcessor,RequiredAnnotationBeanPostProcessor

注: @Resource注解在spring安装目录的lib\j2ee\common-annotations.jar

   
在java代码中使用@Autowired或@Resource注解方式进行装配,这两个注解的区别是:

  @Autowired
默认按类型装配,
 
@Resource默认按名称装配,当找不到与名称匹配的bean才会按类型装配。

例如:
    
a、
@Autowired 

@Autowired    
//从xml文件中寻找到类型为PersonDao的bean后初始化personDao

private PersonDao 
personDao;//用于字段上
   @Autowired
 public void
setPersonDao(PersonDaopersonDao)

//用于属性的set方法上
 {

this.personDao = personDao;
 }
 @Autowired注解是按类型装配依赖对象,默认情况下它要求依赖对象必须存在,如果允许null值,可以设置它required属性为false。如:@Autowired(required=false)

private PersonDao  personDao;//用于字段上
@Autowired(request=false)
public void setPersonDao(PersonDaopersonDao) {
 //用于属性的set方法上
   this.personDao =
personDao;
  }

如果我们想使用按名称装配,可以结合@Qualifier注解一起使用。如下:
   
@Autowired@Qualifier("personDao")
  private 
PersonDao  personDao;//用于字段上
   
@Autowired
public void setPersonDao(@Qualifier("personDao") PersonDao
personDao) {//用于属性的set方法上
   this.personDao=
personDao;
    }
 @Qualifier注解也能够被指定为构造器的参数或者方法的参数:

------------------------------------------------------------

  b、@Resource注解

@Resource注解和@Autowired一样,也可以标注在字段或属性的setter方法上.

@Resource注解默认按名称装配。

名称可以通过@Resource的name属性指定,如果没有指定name属性,

当注解标注在字段上,即默认取字段的名称作为bean名称寻找依赖对象

当注解标注在属性的setter方法上,即默认取属性名作为bean名称寻找依赖对象。
 如:

//从xml文件中寻找到名字为personDao的bean后初始化personDao
@Resource(name="personDao")
 private
PersonDao personDao;//用于字段上
    
@Resource(name="personDao")
  public void setPersonDao(PersonDao
personDao)
 {//用于属性的set方法上
   this.personDao =
personDao;
 }
  后一种相当于xml配置文件中的
 <property name=“personDao"
ref="personDao" />
 
注意:如果没有指定name属性,并且按照默认的名称找不到依赖对象时,
@Resource注解会回退到按类型装配。但一旦指定了name属性,就只能按名称装配了。

、依赖注入--自动装配—注解方式

   自动装配是指,Spring
在装配 Bean 的时候,根据指定的自动装配规则,将某个 Bean 所需要引用类型的 Bean
注入进来。<bean> 元素提供了一个指定自动装配类型的 autowire
属性,该属性有如下选项:
  如:

<bean id=“foo”class=“...Foo” autowire=“autowire
type”>

    autowire属性取值如下


byType:按类型装配,可以根据属性的类型,在容器中寻找跟该类型匹配的bean。如果发现多个,那么将会抛出异常。如果没有找到,即属性值为null。

*
byName:按名称装配,可以根据属性的名称,在容器中寻找跟该属性名相同的bean,如果没有找到,即属性值为null。

*constructor与byType的方式类似,不同之处在于它应用于构造器参数。如果在容器中没有找到与构造器参数类型一致的bean,那么将会抛出异常。

*autodetect
:首先尝试使用constructor来自动装配,然后使用byType方式。不确定性的处理与constructor方式和byType方式一致。

通过在classpath自动扫描方式把组件纳入spring容器中管理

前面的例子我们都是使用XML的bean定义来配置组件。在一个稍大的项目中,通常会有上百个组件,如果这些组件采用xml的bean定义来配置,显然会增加配置文件的体积,查找及维护起来也不太方便。

spring2.5为我们引入了组件自动扫描机制,它可以在类路径底下寻找标注了@Component、@Service、
@Controller、@Repository注解的类,并把这些类纳入进spring容器中管理。它的作用和在xml文件中使用bean节点配置组件
是一样的。

要使用自动扫描机制,我们需要打开以下配置信息:

  
1、引入context命名空间 需要在xml配置文件中配置以下信息:

<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-3.0.xsd

 http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-3.0.xsd">

 <context:component-scan
base-package="com.dao.impl,com.biz.impl,com.util,com.intercept"/>

</beans>

 注意到:在配置文件中添加context:component-scan标签

<context:component-scan
base-package="com.dao.impl,com.biz.impl,com.util,com.intercept"/>

其中base-package为需要扫描的包(含子包),他会将这些包下的类自动装配成bean,并且bean的名字为该类的类名,但首字母小写。
  注:
 
1、在使用组件扫描元素时,AutowiredAnnotationBeanPostProcessor和CommonAnnotationBeanPostProcessor会隐式地被包括进来。
也就是说,连个组件都会被自动检测并织入 - 所有这一切都不需要在XML中提供任何bean配置元数据。
  2、功能介绍
  @Service用于标注业务层组件、
  @Controller用于标注控制层组件(如struts中的action)、
  @Repository用于标注数据访问组件,即DAO组件。
  而@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
//HibernateUtil
,

  
@Component  //
指定该类为Component组件

public class HibernateUtil
{

//从xml文件中寻找到名字为sessionFactory的bean后初始化sessionFactory
   
@Resource(name =
"sessionFactory")

    private
SessionFactory factory;
   
//该属性可以无get/set 方法

     ....
}
//Dao层 
 import
org.springframework.stereotype.Repository;
 import com.test.dao.PersonDao;
 
@Repository 
//指定该类为Repository组件

public class PersonDaoBean implements PersonDao
{
   
//即默认取字段的名称作为bean名称寻找依赖对象,即hibernateUtil
   
@Resource
    private
HibernateUtil hibernateUtil;....
                           
}
 //业务层/Service层
import javax.annotation.Resource;

import org.springframework.stereotype.Service;
import com.test.dao.PersonDao;
import com.test.service.PersonService;
 
@Service 

//指定该组件为Service组件
  public class PersonServiceBean implements
PersonService {
  
@Resource 
//即默认取字段的名称作为bean名称寻找依赖对象
   private PersonDao
personDao;
....
        
}
//控制层/Controller层
@Controller//指定该组件为Controller组件
public class AccountMngAction
{

//即默认取字段的名称作为bean名称寻找依赖对象
   
@Resource
    private
CheckInBiz checkInBiz;
   
@Resource
    private
RoomBiz roomBiz;
   
@Resource
    private
AccountBiz accountBiz;
....
}

Spring学习3—控制反转(IOC)基于Annotation(注解)的依赖注入实现的更多相关文章

  1. Spring框架系列(3) - 深入浅出Spring核心之控制反转(IOC)

    在Spring基础 - Spring简单例子引入Spring的核心中向你展示了IoC的基础含义,同时以此发散了一些IoC相关知识点; 本节将在此基础上进一步解读IOC的含义以及IOC的使用方式.@pd ...

  2. Spring学习3—控制反转(IOC)Spring依赖注入(DI)和控制反转(IOC)

    一.思想理解 Spring 能有效地组织J2EE应用各层的对象.不管是控制层的Action对象,还是业务层的Service对象,还是持久层的DAO对象,都可在Spring的 管理下有机地协调.运行.S ...

  3. 通过laravel理解IoC(控制反转)容器和DI(依赖注入)

    原文地址: http://www.insp.top/learn-laravel-container ,转载务必保留来源,谢谢了! 容器,字面上理解就是装东西的东西.常见的变量.对象属性等都可以算是容器 ...

  4. spring中的控制反转IoC和依赖注入DI

    原文:http://blog.163.com/xianghuxian@126/blog/static/50639037200721345218382/ IoC(Inversion of Control ...

  5. Spring_01 spring容器、控制反转(IOC)、依赖注入(DI)

    目录 1 什么是spring框架 2 spring框架的特点 3 spring容器 3.1 什么是spring容器 3.2 spring容器创建对象的编程步骤 3.4 spring容器创建对象的方式 ...

  6. Spring 概念及特点 Spring下载地址 控制反转IoC实现原理

    Spring下载地址 http://repo.springsource.org/libs-release-local/org/springframework/spring/ Spring是开源full ...

  7. 吴裕雄--天生自然JAVA SPRING框架开发学习笔记:Spring声明式事务管理(基于Annotation注解方式实现)

    在 Spring 中,除了使用基于 XML 的方式可以实现声明式事务管理以外,还可以通过 Annotation 注解的方式实现声明式事务管理. 使用 Annotation 的方式非常简单,只需要在项目 ...

  8. Spring学习02——控制反转、依赖注入

    有两个人,张三和李四 package com.su.service; public class ZhangSan implements Tester{ public void test(){ Syst ...

  9. Spring学习(十八)Bean 的三种依赖注入方式介绍

    依赖注入:让调用类对某一接口实现类的依赖关系由第三方注入,以移除调用类对某一接口实现类的依赖.接下来将详细的向大家介绍Spring容器支持的三种依赖注入的方式以及具体配置方法:•    属性注入方法• ...

随机推荐

  1. linux vmstat 系统结果说明

    可以用vmstat 显示系统负载等信息. 例如 vmstat 5 5,表示在T(5)秒时间内进行N(5)次采样. procs:r-->;在运行队列中等待的进程数b-->;在等待io的进程数 ...

  2. iBatis.Net(C#)数据库查询

    引用请注明http://www.cnblogs.com/13590/archive/2013/03/14/2958735.html  摘要:查询是数据库SQL语言的核心,本文介绍了通过iBatis.N ...

  3. iBatis.Net实现返回DataTable和DataSet对象

    如题.要返回一个ADO.NET对象好像没有使用ORM的必要,而且从编程的角度看这样的实现一点也不OO,但是实际的开发场景中还是会碰到这种需求的.下面我就借鉴前人的经验,结合实际的示例,再总结一下.如果 ...

  4. 用python简单处理图片(2):图像通道\几何变换\裁剪

    一.图像通道 1.彩色图像转灰度图 from PIL import Image import matplotlib.pyplot as plt img=Image.open('d:/ex.jpg') ...

  5. Caffe学习系列(14):初识数据可视化

    //   首先将caffe的根目录作为当前目录,然后加载caffe程序自带的小猫图片,并显示. 图片大小为360x480,三通道 In [1]: import numpy as np import m ...

  6. java web 的标准目录结构(zz)

    http://blog.csdn.net/bluesnail216/article/details/7744607 --yourproject    --src       --java   运行的j ...

  7. Linux(10.5-10.11)学习笔记

    3.2程序编码 unix> gcc -01 -o p p1.c p2.c -o用于指定输出(out)文件名. -01,-02 告诉编译器使用第一级或第二级优化 3.2.1机器级代码 机器级编程两 ...

  8. IT行业工作6年回顾

    IT行业工作6年回顾 时间一晃,已经出来工作六七年了,当真岁月如梭,时光如箭,回首往昔,当真叹一句:“太多东西都失于路上”,今天偷得浮生半日闲,做个回顾,权当是给自己做个小结,也希望给他人一些可用的借 ...

  9. 编写高质量代码改善C#程序的157个建议[协变和逆变]

    前言 本文已更新至http://www.cnblogs.com/aehyok/p/3624579.html .本文主要学习记录以下内容: 建议42.使用泛型参数兼容泛型接口的不可变性 建议43.让接口 ...

  10. WPF--Dispatcher.BeginInvoke()方法使用不当导致UI界面卡死的原因分析

    原文地址: http://www.tuicool.com/articles/F7reem http://blog.csdn.net/yl2isoft/article/details/11711833 ...