Spring2.5注释语法(上)——Spring2.5注释驱动的IoC

2024-02-12 16:18

本文主要是介绍Spring2.5注释语法(上)——Spring2.5注释驱动的IoC,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://tonyaction.blog.51cto.com/227462/107451

 

Spring2.5 注释语法()
            ——Spring2.5 注释驱动的IoC
 
  正如Spring 框架的名称一样,它真的为我们JavaEE 开发带来了一阵春风,而其著名的IoC ( 依赖注入) 更是为它的经久不衰注入了无限活力。在新发布的2.5 版本中Spring 的开发者为我们这些使用Java5 或更高版本Java 的开发人员提供了进一步简化而强大的新特性。其中就包括了注释驱动的依赖性注入(annotation-driven dependency injection )和新的web 控制器模型将请求映射到加注释的方法上,等等。
  今天我首先要向大家介绍的就是Spring2.5 中新特性之一--- 注释驱动的依赖性注入,在正式介绍之前我想先让大家了解一下什么是注释,请看下面的代码清单:
一、了解Java 注释
代码清单1.1
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
 
@Retention(RetentionPolicy.RUNTIME )
public @interface MyAnnotation { ①定义一个注释
int init();
}
 
  代码清单1.2
import java.lang.annotation.Annotation;
public class TestAnnotation {
  @MyAnnotation(init = 2) ②使用注释
  public void print(){
     System.out .println(TestAnnotation.class .getName());
  }
  public static void main(String[] args) throws Exception{
     TestAnnotation ta = new TestAnnotation();
     Annotation[] annotations = ta.getClass().getMethod("print").getAnnotations();
     for (Annotation annotation : annotations)  {             
         System.out .println("MyAnnotation.init : " +
       ((MyAnnotation)annotation).init()); ④打印出init 的值
        }
  }
}
在代码清单1.1 中我们定义了一个名为MyAnnotation 的注释而这个注释中只有一个类型为int 名为init 的属性,代码清单1.2 中我们在 处使用了我们刚刚定义的注释并且为init 赋值为2 ,在 处我们通过反射机制获得print 方法上定义的所有注释然后通过迭代将其值init 打印至控制台。
最终在控制台输出以下信息:
MyAnnotation.init : 2
  至此我们对Java 中的注释有了一个简单的了解,下面我们来看看Spring2.5 是如何使用这些注释来完成它神奇的IoC 功能吧。在此之前我们先来看看以前我们是怎么做的。
二、SpringIoC
代码清单2.1
public class Foo {
  private String name;
  private int age;
  public String toString(){
     return "The Foo's Name is : " + this .name + " The Foo's Age is : " + this .age;
  }
  public String getName() {...}
  public void setName(String name) {...}
  public int getAge() {...}
  public void setAge(int age) {...}
}
代码清单2.2
public class Bar {
  private String address;
  public String toString(){
     return "The Bar's Address is : " + this .address;
  }
  public String getAddress() {...}
  public void setAddress(String address) {...}
}
代码清单2.3
public class Base {
  private Foo foo;
  private Bar bar;
  public String toString(){
     return "Base : [" + this .foo.toString() +" "+ this .bar.toString()+ "]";
  }
  public Foo getFoo() {...}
  public void setFoo(Foo foo) {...}
  public Bar getBar() {...}
  public void setBar(Bar bar) {...}
}
代码清单2.4
<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="..." >
  <bean id="foo" class="com.tony.test.Foo" >
     <property name="name" value="Tony" />
     <property name="age" value="27" />
  </bean >
  <bean id="bar" class="com.tony.test.Bar" >
     <property name="address" value="China Tianjin" />
  </bean>
  <bean id="base" class="com.tony.test.Base" >
     <property name="foo" >
        <ref local="foo" />
     </property>
     <property name="bar" >
        <ref local="bar" />
     </property>
  </bean>
</beans>
代码清单2.5
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class MainClass {
  public static void main(String[] args) {   
        String[] locations = {"spring-config-beans.xml"};   
        ApplicationContext ctx = new ClassPathXmlApplicationContext(locations);   
        Base main = (Base) ctx.getBean("base");   
        System.out.println(main);   
   }
}
我们来看看上面代码的含义,首先在代码 处我们分别定义了两个名为FooBarBean ,在 处我们通过set 方法将两个Bean 注入进Base 类中,并且在Base 类中定义了toString 方法来打印出FooBar 的信息, 处我们定义了一个MainClass 来执行我们的代码, 处我们通过getBean 获得配置文件中配置的idbaseBean 并在 出将其信息打印至控制台, 控制台输出信息如下:
Base : [The Foo's Name is : Tony The Foo's Age is : 27 The Bar's Address is : China Tianjin]
看到上面习以为常的配置信息和set get 方法我们根本不会有任何想法,可是当我们看到了Spring2.5 注释特性的时候我们发现自己真的错了,程序竟然还可以写成这么简单。
三、使用@Autowired 注释
经过了一番整理我们把改好了。
代码清单3.1
import org.springframework.beans.factory.annotation.Autowired;
public class Base {
  @Autowired ① 使用了一个名为Autowired 的注释
  private Foo foo;
  @Autowired
  private Bar bar;
  public String toString(){
     return "Base : [" + this .foo.toString() +" "+ this .bar.toString()+ "]";
  }
}
代码清单3.2
  <!-- BeanPostProcessor 将自动对标注 @Autowired Bean 进行注入 --> 
  <bean class="org.springframework.beans.factory.annotation.
                              AutowiredAnnotationBeanPostProcessor" />
 
  <bean id="foo" class="com.tony.test.Foo" >
     <property name="name" value="Tony" />
     <property name="age" value="27" />
  </bean>
  <bean id="bar" class="com.tony.test.Bar" >
     <property name="address" value="China Tianjin" />
  </bean>
  <!-- 此时移除了Base 的配置信息 -->
  <bean id="base" class="com.tony.test.Base" />
以上的代码清单中我们在 处使用了 @Autowired 注释, 它可以对类的成员变量、方法及构造函数进行标注,完成自动装配的工作,在 处我们为了使 @Autowired 注释 生效必须在Spring 容器中声明 AutowiredAnnotationBeanPostProcessor Bean 它通过 扫描 Spring 容器中所有 Bean ,当发现 Bean 中拥有 @Autowired 注释时就找到和其相匹配(默认按类型匹配)的 Bean ,并将其注入 , 而此时我们在声明Base 的时候( ) 就不用写它的配置信息了,更可以将Base 类中的setget 方法删除。 @Autowired 还可以通过类的构造函数来进行自动装配。
代码清单3.3
import org.springframework.beans.factory.annotation.Autowired;
public class Base {
  private Foo foo;
  private Bar bar;
  @Autowired
  public Base(Foo foo,Bar bar){
     this .foo = foo;
     this .bar = bar;
  }
  public String toString(){
     return "Base : [" + this .foo.toString() +" "+ this .bar.toString()+ "]";
  }
}
在代码清单3.3 中我们增加了一个构造函数,通过它来对我们的成员变量进行赋值,我们同时也为这个构造函数添加了@Autowired 注释( 处)使其可以自动将FooBar 两个成员变量装配进来。
四、使用@Qualifier 注释
有时我们会遇到这样一种情况,我们定义了两个类型相同数据不同的Bean ,我们此时需要用到其中一个Bean 来供我们使用,使用@Qualifier 注释就可以满足我们的要求,当使用@Qualifier 注释时 自动注入的策略就从 byType 转变成 byName 了。
代码清单4.1
<bean id="bar" class="com.tony.test.Bar" >
  <property name="address" value="China Tianjin" />
</bean>
<bean id="bar2" class="com.tony.test.Bar" >
  <property name="address" value="China Beijing" />
</bean>
代码清单4.2
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
public class Base {
  private Bar bar;
  @Autowired  ③
  public Base(@Qualifier("bar2")Bar bar){  ④
     this .bar = bar;
  }
  public String toString(){
     return "Base : ["+ this .bar.toString()+ "]";
  }
}
代码清单4.1 中的 处我们分别定义了两个类型为BarBeanBaraddressChina Beijing 并且Bean 的名称为bar2 ,在代码清单4.2 处我们同样使用了@Autowired 注释为Bar 的构造函数进行自动装配,可是在 处我们通过@Qualifier("bar2") 来明确指定我们需要将idbar2Bean 装配进来。我们还可以为成员变量使用@Qualifier 注释。
代码清单4.3
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
public class Base {
  @Autowired
  @Qualifier("bar2")
  private Bar bar;
  public String toString(){
     return "Base : ["+ this .bar.toString()+ "]";
  }
}
代码清单4.3 中我们为成员变量bar 添加了两个注释 处是我们已经很熟悉的@Autowired 注释,紧随其后的就是@Qualifier 注释。 @Qualifier 注释可以对成员变量、方法入参、构造函数入参进行标注,而我们最常用也最方便的就是为成员变量使用注释。
五、使用@Component 注释
使用了@Autowired 注释后我们发现自动注入真的非常简单,但是我们还是得在配置文件中定义相应的<Bean> ,如果我们能在配置文件中完全移除Bean 的定义那就更好了,Spring2.5 就为我们提供了这一可能。
代码清单5.1
import org.springframework.stereotype.Component;
@Component
public class Bar {
  private String address = "China Tianjin";
  public String toString(){
     return "The Bar's Address is : " + this .address;
  }
}
 
代码清单5.2
import org.springframework.stereotype.Component;
@Component("base")
public class Base {
  @Resource
  private Bar bar;
  public String toString(){
     return "Base : ["+ this.bar.toString()+ "]";
  }
}
 
代码清单5.3
<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="..." >
  <context:component-scan base-package="com.tony.test"/>
</beans>
在代码清单5.1 中我们使用了一个 @Component 注释( 处), 使用 @Component 注释就可以将一个类定义成为Spring 容器中的 Bean 。在代码清单5.2 处我们也同样使用了@Component 注释,而此时我们使用了它提供的一个可选的入参将Bean 的名称定义为base ,最后在 处我们将以前定义Bean 的内容全部移除,添加了一行 <context:component-scan/> ,其中的 base-package 属性 指定了需要扫描的类包,它会自动递归下面的子包。
六、使用@Scope 注释
代码清单6.1
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component;
@Scope("prototype")
@Component("base")
public class Base {
  @Autowired
  private Bar bar;
  public String toString(){
     return "Base : ["+ this .bar.toString()+ "]";
  }
}

在代码清单6.1 中的 处我们添加了一个@Scope 注释,这样当我们从 Spring 容器中获取 base 时,每次返回的都是一个新的实例了。

 

 

另外参见:http://www.infoq.com/cn/articles/spring-2.5-part-1


这篇关于Spring2.5注释语法(上)——Spring2.5注释驱动的IoC的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/702993

相关文章

Python正则表达式语法及re模块中的常用函数详解

《Python正则表达式语法及re模块中的常用函数详解》这篇文章主要给大家介绍了关于Python正则表达式语法及re模块中常用函数的相关资料,正则表达式是一种强大的字符串处理工具,可以用于匹配、切分、... 目录概念、作用和步骤语法re模块中的常用函数总结 概念、作用和步骤概念: 本身也是一个字符串,其中

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Spring 基于XML配置 bean管理 Bean-IOC的方法

《Spring基于XML配置bean管理Bean-IOC的方法》:本文主要介绍Spring基于XML配置bean管理Bean-IOC的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录一. spring学习的核心内容二. 基于 XML 配置 bean1. 通过类型来获取 bean2. 通过

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

idea中创建新类时自动添加注释的实现

《idea中创建新类时自动添加注释的实现》在每次使用idea创建一个新类时,过了一段时间发现看不懂这个类是用来干嘛的,为了解决这个问题,我们可以设置在创建一个新类时自动添加注释,帮助我们理解这个类的用... 目录前言:详细操作:步骤一:点击上方的 文件(File),点击&nbmyHIgsp;设置(Setti