注解在很多框架中开始流行起来,这源于注解的方便,java提供的常用三种注解:@Override,@Deprecated(用于方法上,标记此方法已过时),@SuppressWarnings。
注解的格式:
@Retention(RetentionPolicy.RUNTIME)//元注解 內存中字節碼階段
@Target(value={ElementType.METHOD,ElementType.TYPE})//指定多个值时用数组{}
public @interface MyAnnotation {
String value() default "hello"; //只有value屬性,在使用時可以不用指明value字段,可以直接寫值
String fruit();
int[] arr();
Week we() default Week.Monday;
}
@Retention:value属性值有RetentionPolicy.RUNTIME,对应着内存中字节码阶段;RetentionPolicy.SOURCE对应java源文件阶段RetentionPolicy.CLASS对应class文件阶段
@Target:限定注解用在何處,上面定的是方法和類上
在注解中增加属性,属性的类型可以是基本类型,也可以是引用类型,上面只是用了String、Enum、Array类型
在用到注解的地方如果属性没有默认值(default)则必须指定值,注解中只有value屬性时,在使用時可以不用指明value字段而直接写值如@MyAnnotation(“test”);如果數組只有一個內容時,可以直接寫成arr=1,就像@Target(ElementType.METHOD)。下面是一个用例:
@MyAnnotation(fruit = "apple",arr={3,4,5})//如果數組只有一個內容時,可以直接寫成arr=1,就像@Target(ElementType.METHOD)
public class Demo{
public static void main(String[] args) {
Class clz=Demo.class;
if(clz.isAnnotationPresent(MyAnnotation.class)){//判断此类是否有注解
MyAnnotation ma=(MyAnnotation) clz.getAnnotation(MyAnnotation.class);//获得此注解
System.out.println(ma.fruit()+ma.value()+" "+ma.arr().length);//获得注解的属性值
}
}
}