使用Spring2.5的Autowired实现注释型的IOC  161641
 
使用Spring2.5的新特性——Autowired可以实现快速的自动注入,而无需在xml文档里面添加bean的声明,大大减少了xml文档的维护。(偶喜欢这个功能,因为偶对xml不感冒)。      以下是一个例子: 
先编写接口Man: 
  public interface Man { 
      public String sayHello(); 
然后写Man的实现类Chinese和American: 
@Service 
public class Chinese implements Man{ 
    public String sayHello() { 
        return "I am Chinese!"; 
    } 
 
@Service 
public class American implements Man{ 
    public String sayHello() { 
        return "I am American!"; 
    } 
    @Service注释表示定义一个bean,自动根据bean的类名实例化一个首写字母为小写的bean,例如Chinese实例化为chinese,American实例化为american,如果需要自己改名字则:@Service("你自己改的bean名")。 
 
<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="/schema/beans" 
        xmlns:xsi="/2001/XMLSchema-instance" 
        xmlns:context="/schema/context" 
        xsi:schemaLocation="/schema/beans   
          /schema/beans/spring-beans-2.5.xsd 
          /schema/context 
          /schema/context/spring-context-2.5.xsd"> 
      <context:annotation-config/> 
      <context:component-scan base-package="testspring.main"/> 
</beans> 
在spring的配置文件里面只需要加上<context:annotation-config/>和<context:component-scan base-package="需要实现注入的类所在包"/>,可以使用base-package="*"表示全部的类。 
编写主类测试: 
@Service 
public class Main { 
    @Autowired 
    @Qualifier("chinese") 
    private Man man; 
 
    public static void main(String[] args) { 
        // TODO code application logic here 
        ApplicationContext ctx = new ClassPathXmlApplicationContext("l"); 
        Main main = (Main) Bean("main"); 
        System.out.Man().sayHello()); 
    } 
 
    public Man getMan() { 
        return man; 
    } 
 
在Man接口前面标上@Autowired和@Qualifier注释使得Man接口可以被容器注入,当Man接口存在两个实现类的时候必须指定其中一个来注入,使用实现类首字母小写的字符串来注入。否则可以省略,只写@Autowired   
 
********************** 
使用 Spring 2.5 注释驱动的 IoC 功能 
 
注释配置相对于 XML 配置具有很多的优势: 
 
它可以充分利用 Java 的反射机制获取类结构信息,这些信息可以有效减少配置的工作。如使用 JPA 注释配置 ORM 映射时,我们就不需要指定 PO 的属性名、类型等信息,如果关系表字段和 PO 属性名、类型都一致,您甚至无需编写任务属性映射信息——因为这些信息都可以通过 Java 反射机制获取。   
注释和 Java 代码位于一个文件中,而 XML 配置采用独立的配置文件,大多数配置信息在程序开发完成后都不会调整,如果配置信息和 Java 代码放在一起,有助于增强程序的内聚性。而采用独立的 XML 配置文件,程序员在编写一个功能时,往往需要在程序文件和配置文件中不停切换,这种思维上的不连贯会降低开发效率。   
因此在很多情况下,注释配置比 XML 配置更受欢迎,注释配置有进一步流行的趋势。Spring 2.5 的一大增强就是引入了很多注释类,现在您已经可以使用注释配置完成大部分 XML 配置的功能。在这篇文章里,我们将向您讲述使用注释进行 Bean 定义和依赖注入的内容。 
 
原来我们是怎么做的 
 
在使用注释配置之前,先来回顾一下传统上是如何配置 Bean 并完成 Bean 之间依赖关系的建立。下面是 3 个类,它们分别是 Office、Car 和 Boss,这 3 个类需要在 Spring 容器中配置为 Bean: 
 
Office 仅有一个属性: 
 
 
清单 1. Office.java 
                 
package com.baobaotao; 
public class Office { 
    private String officeNo =”001”; 
 
    //省略 get/setter 
 
    @Override 
    public String toString() { 
        return "officeNo:" + officeNo; 
    } 
   
 
 
Car 拥有两个属性: 
清单 2. Car.java 
                 
package com.baobaotao; 
 
public class Car { 
    private String brand; 
    private double price; 
    // 省略 get/setter 
      @Override 
    public String toString() { 
        return "brand:" + brand + "," + "price:" + price; 
    } 
   
Boss 拥有 Office 和 Car 类型的两个属性: 
 
清单 3. Boss.java 
package com.baobaotao; 
public class Boss { 
    private Car car; 
    private Office office; 
    // 省略 get/setter 
    @Override 
    public String toString() { 
        return "car:" + car + "\n" + "office:" + office; 
    } 
我们在 Spring 容器中将 Office 和 Car 声明为 Bean,并注入到 Boss Bean 中:下面是使用传统 XML 完成这个工作的配置文件 l: 
清单 4. l 将以上三个类配置成 Bean  spring ioc注解
<?xml version="1.0" encoding="UTF-8" ?> 
<beans xmlns="/schema/beans" 
    xmlns:xsi="/2001/XMLSchema-instance" 
    xsi:schemaLocation="/schema/beans   
/schema/beans/spring-beans-2.5.xsd"> 
    <bean id="boss" class="com.baobaotao.Boss"> 
        <property name="car" ref="car"/> 
        <property name="office" ref="office" /> 
    </bean> 
    <bean id="office" class="com.baobaotao.Office"> 

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。