注解(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。 
有关注解的更详细说明,参考这里。
   
 
  |