概述:注解(Annotation)其实就是代码里的特殊标记, 这些标记可以在编译, 类加 载, 运行时被读取, 并执行相应的处理。通过使用 Annotation, 程序员 可以在不改变原有逻辑的情况下, 在源文件中嵌入一些补充信息。
在JavaSE中,注解的使用目的比较简单,例如标记过时的功能,忽略警告等。在JavaEE/Android中注解占据了更重要的角色,例如用来配置应用程序的任何切面,代替JavaEE旧版中所遗留的繁冗代码和XML配置等
如何自定义注解:参照@SuppressWarnings定义
-
注解声明为@interface
-
内部定义成员,通常使用value表示
-
可以指定成员的默认值,使用default定义
-
如果自定义注解没有成员,表明是一个标识作用
示例:
public @interface MyAnnotation {
String value() default "hello";
}
说明:
-
如果注解有成员,在使用注解时,需要指明成员的值
-
自定义注解必须配上注解的信息处理流程(使用反射)才有意义
-
自定义注解通常都会指明两个元注解@Retention,@Target
元注解:对现有的注解进行解释说明的注解
@Retention: 只能用于修饰一个 Annotation 定义, 用于指定该 Annotation 的生命 周期
@Target: 用于修饰 Annotation 定义, 用于指定被修饰的 Annotation 能用于 修饰哪些程序元素。
示例:
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.TYPE,ElementType.METHOD,ElementType.CONSTRUCTOR,ElementType.LOCAL_VARIABLE,ElementType.TYPE_PARAMETER,ElementType.TYPE_USE})
public @interface MyAnnotation {
String value() default "hello";
}