Annotation是一种特殊的interface。所以可以在annotation里定义方法,属性;也可以让某个类从annotation继承(implements)。
下面从简单地范例开始,让我们一步步加深对annotation的了解。
无任何方法/属性Annotation范例:
MyAnnotation0.java
package com.test.annotation;
public @interface MyAnnotation0 {
}
MyAnnotation0为一个无任何方法和属性的annotation。
使用MyAnnotation0:
TestMyAnnotation0.java
@MyAnnotation0
public class TestMyAnnotation0 {
@MyAnnotation0
public void testMethod() {
}
}
具有一个value方法Annotation范例:
MyAnnotation1.java
public @interface MyAnnotation1 {
/**
* value method
* @return value
*/
public String value();
}
MyAnnotation1具有一个名为value的方法。
MyAnnotation1使用:
TestMyAnnotation1.java
@MyAnnotation1("hello")
public class TestMyAnnotation1 {
@MyAnnotation1(value="world")
public void testMethod() {
}
}
可以通过@Annotation名(方法名1=值1, 方法名2=值2, …)的形式给annotation赋值。只有一个方法的时候,可以直接省略为:@Annotation名(值1) 的赋值形式。当方法返回一个数组时,可以用 方法名={值1, 值2, …}给其赋值。
具有一个value方法和一个属性Annotation范例:
如果必要,还可以在annotation里为其定义属性。如下:
MyAnnotation2.java
@interface MyAnnotation2 {
public String value();
public String myProperty = "hello world";
}
其中,myProperty只能申明为public或无public修饰(无public修饰时也默认为public)为static, final属性(即使不写也默认为static, final)。
使用例:
TestMyAnnotation2
class TestMyAnnotation2 {
public static void main(String[] args) {
System.out.println(MyAnnotation2.myProperty);
}
@MyAnnotation2("")
public void testMethod1() {
}
}
上例会打印出:
hello world
复杂型annotation的定义与使用
本节介绍较为复杂的annotation定义与使用。
先看代码:
MyAnnotation3.java
public @interface MyAnnotation3 {
public String value();
public String[] multiValues();
int number() default 0;
}
MyAnnotation3具有一个返回String的value方法,返回String[]的multiValues 方法;还有一个返回int 的number方法。其中number方法具有默认值0。
使用例:
TestMyAnnotation3.java
class TestMyAnnotation3 {
@MyAnnotation3(value = "call testMethod1", multiValues={"1", "2"}, number = 1)
public void testMethod1() {
}
@MyAnnotation3(value = "call testMethod2", multiValues={"1", "2"})
public void testMethod2() {
}
}
number具有默认值,所以标注时可以不为其赋值。其余方法则必须通过上面介绍的方法赋值。multiValues返回一个String[]数组,所以可以通过multiValues={"1", "2"}为其赋值。
posted on 2009-02-27 17:21
ID刀 阅读(602)
评论(0) 编辑 收藏 所属分类:
JAVA_Base