Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·hibernate配置笔记
·AOP编程入门--Java篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·在win2003下整合了整合Tomcat5.5+ apache_2.0.53+ mod_jk_2.0.47.dll
·构建Linux下IDE环境--Eclipse篇
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·ASP、JSP、PHP 三种技术比较
·Tomcat5.5.9的安装配置
·AWT GUI 设计笔记(二)

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
[J2SE 5.0专题][2.7]注解

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

注解(Annotations)在我看来是J2SE 5.0中比较重大的新特性。将来的EJB 3.0规范将会全面利用该特性来简化Session Bean、 Message-Driven Bean和EntityBean的定义和实现。

Java的注解或多或少也是受了.NET的影响。这不是说Java本来没有注解,以前的诸如JavaDoc的标注,尤其@deprecated,都是注解,只不过这一次的更新将注解推到了Java历史上前所未有的高度。通过注解,我们可以实现原先相对复杂的高级功能。

先看一个实际的例子:

/*
 * Created on 2004-12-28
 *
 */

import java.lang.annotation.*;

/**
 * @author Sean
 *
 */
public class MyAnnotations {

    @MyAnnotationForMethods (
            index = 1,
            info = "This is a method to test MyAnnotation.",
            developer = "Somebody else"
    )
    public void testMethod1() {
        // ...
    }

    @MyEmptyAnnotation
    @MySingleElementAnnotation("For instruction purpose only.")
    @MyAnnotationForMethods (
            index = 2,
            info = "This method is to show multiple annotations."
    )
    public void testMethod2() {
        // ...
    }
   
}

@Target(ElementType.METHOD)
@interface MyAnnotationForMethods {
    int index();
    String info();
    String developer() default "Sean GAO";
}

@interface MyEmptyAnnotation { 
}

@interface MySingleElementAnnotation {
    String value();
}

在这个例子中,我先后定义了三个注解:第一个MyAnnotationForMethods包含三个成员,分别是index、info和developer,其中developer有默认值"Sean GAO",前面的@Target(ElementType.METHOD)是对这个注解的注解,说明该注解只能用于方法;第二个MyEmptyAnnotation是一个空的注解,可以作为标记使用,如早先的Serializable接口;第三个MySingleElementAnnotation包含一个成员,value,这个是硬性规定,当只有一个元素时,必须用value这个名称,它的类型可以是值型、String、Class、enum、或者上述数据类型的一元数组。

注解的定义很像接口,但是他们跟接口在用法上又有相当大的区别。具体的用法参考我上面举的例子。注解是可以叠加的。

在实际应用中,目前比较成熟的是一些测试框架,如我在另一篇文章中翻译的原作者Cedric Beust编写的TestNG。而在本文的开始,我曾经提到在将来的EJB 3.0规范中会有相当多的对注解的应用,让我们预览一下将来的无状态会话bean用注解来定义会是什么样子:

@Stateless public class BookShelfManagerBean {
    public void addBook(Book aBook) {
        // business logic goes here...
    }
    public Collection getAllBooks() {
        // business logic goes here...
    }
    // ...
}

That's it. 我们甚至不用写任何接口和部署描述符,how nice。

有关注解的更详细说明,参考这里




相关文章

相关软件