常用注解简介
1.@interface实际上是继承了java.lang.annotation.Annotation,所以定义annotation时不能继承其他annotation或interface. java.lang.annotation.Retention告诉编译器如何对待 Annotation,使用Retention时,需要提供java.lang.annotation.RetentionPolicy的枚举值: SOURCE, // 编译器处理完Annotation后不存储在class中 CLASS, // 编译器把Annotation存储在class中,这是默认值 RUNTIME // 编译器把Annotation存储在class中,可以由虚拟机读取,反射需要 java.lang.annotation.Target告诉编译器Annotation使用在哪些地方,使用需要指定 java.lang.annotation.ElementType的枚举值: TYPE, // 指定适用点为 class, interface, enum FIELD, // 指定适用点为 field METHOD, // 指定适用点为 method PARAMETER, // 指定适用点为 method 的 parameter CONSTRUCTOR, // 指定适用点为 constructor LOCAL_VARIABLE, // 指定使用点为 局部变量 ANNOTATION_TYPE, //指定适用点为 annotation 类型 PACKAGE // 指定适用点为 package java.lang.annotation.Documented用于指定该Annotation是否可以写入javadoc中. java.lang.annotation.Inherited用于指定该Annotation用于父类时是否能够被子类继承. java.lang.reflect.AnnotatedElement接口提供了四个方法来访问Annotation public Annotation getAnnotation(Class annotationType); public Annotation[] getAnnotations(); public Annotation[] getDeclaredAnnotations(); public boolean isAnnotationPresent(Class annotationType); Class、Constructor、Field、Method、Package等都实现了该接口,可以通过这些方法访问Annotation信息,前提是要访问的Annotation指定Retention为RUNTIME. Java内置的annotation有Override Deprecated SuppressWarnings. Override只用于方法,它指明注释的方法重写父类的方法,如果不是,则编译器报错. Deprecated指明该方法不建议使用 SuppressWarnings告诉编译器:我知道我的代码没问题,你不用吓我了,我不怕的^_^ 这些都是Mark Annotation,名称本身就包含了要提供的信息,不需要额外提供.