关于作者:贾帅
博客: https://shuaijia.github.io/
github:https://github.com/shuaijia
csdn: http://blog.csdn.net/jiashuai94
注解是Java 1.5引入的,可以提供代码的额外信息,目前正在被广泛应用。除了Java内置注解,我们也可以自定义注解。
以下就是一个自定义注解的简单例子:
@Target(ElementType.TYPE) //注解作用于类型(类,接口,注解,枚举)
@Retention(RetentionPolicy.RUNTIME) //运行时保留,运行中可以处理
@Inherited // 注解将被用于该类的子类
@Documented // 生成javadoc文件
public @interface JsAnnotation {
String DEFAULT_VALUE = "JS";
/**
* 创建此value方法,则使用注解时可直接传参,如 @JsAnnotation("msg")
*
* @return
*/
String value() default DEFAULT_VALUE;
}
自定义注解关键点:
元注解就是定义注解的注解。
包含@Target、@Retention、@Inherited、@Documented这四种
描述注解的使用目标。
其源码为:
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.ANNOTATION_TYPE})
public @interface Target {
ElementType[] value();
}
注解方法返回值是ElementType[],ElementType枚举类型,枚举值就是@Target注解的可取值。
方法名value,这样在使用注解时,可以不需要指定方法名。
可取的值有:
2、@Retention
注意:默认可以作用于以上任何目标。
描述注解的生命周期。
其源码为:
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.ANNOTATION_TYPE})
public @interface Retention {
RetentionPolicy value();
}
注解方法返回值是枚举类型RetentionPolicy,枚举值就是@Retention注解的可取值。
可取的值有:
3、@Documented
默认RetentionPolicy.CLASS 值。
描述注解可以文档化,是一个标记注解。
在生成javadoc的时候,是不包含注释的,但是如果注解被@Documented修饰,则生成的文档就包含该注解。
其源码为:
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.ANNOTATION_TYPE})
public @interface Documented {
}
标记注解,使用@Inherited修饰的注解作用于一个类,则该注解将被用于该类的子类。
其源码为:
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.ANNOTATION_TYPE})
public @interface Inherited {
}
@Target(ElementType.TYPE) //注解作用于类型(类,接口,注解,枚举)
@Retention(RetentionPolicy.RUNTIME) //运行时保留,运行中可以处理
@Inherited // 注解将被用于该类的子类
@Documented // 生成javadoc文件
public @interface JsAnnotation {
String DEFAULT_VALUE = "JS";
/**
* 颜色枚举
*
* @author peida
*/
enum Color {
BULE, RED, GREEN
}
/**
* 创建此value方法,则使用注解时可直接传参,如 @JsAnnotation("msg")
*
* @return
*/
String value() default DEFAULT_VALUE;
/**
* 此方法返回为枚举类型,使用注解时,如 @JsAnnotation(color=Color.BLUE)
*
* @return
*/
Color color() default Color.BULE;
int num() default -1;
}
其中:定义了三个方法,三个方法都有默认返回值。定义了Color枚举(因为注解的方法可以返回枚举类型)
这里注意:
@JsAnnotation("jia shuai")
public class AnnotationTest {
}
或
@JsAnnotation(num = 100)
public class AnnotationTest {
}
或
@JsAnnotation(color = Color.BLUE)
public class AnnotationTest {
}
public static void main(String[] args) {
AnnotationTest test = new AnnotationTest();
Class tClass = test.getClass();
JsAnnotation jsAnnotation = (JsAnnotation) tClass.getAnnotation(JsAnnotation.class);
System.out.println(jsAnnotation.value());
System.out.println(jsAnnotation.color());
System.out.println(jsAnnotation.num());
}