在 Java SE API 中预定义了一系列
Annotation。有的用于 Java 编译器,有的用于 Annotation。
1、用于编译器的 Annotation
定义在 java.lang 包中的 @Deprecated @Override 和 @SuppressWarnings
注释。
@Deprecated
@Deprecated 用来标记某个元素不赞成使用。如果应用程序使用的类、方法或字段上添加了 @Deprecated,那么如果在程序中使用了被注释的元素,编译器将会生成警告信息。也可以使用 JavaDoc 的 @deprecated 来标记某个元素不赞成使用,用法和 @Deprecated 类似,不过第一个字母是小写的 d。下面看看
例子:
class="java" name="code">// Javadoc comment follows
/**
* @deprecated
* explanation of why it was deprecated
*/
@Deprecated
static void deprecatedMethod() { }
}
@Override
@Override 用来标记当前的元素重写父类中的元素。例如:
// mark method as a superclass method
// that has been overridden
@Override
int overriddenMethod() { }
虽然在重写方法的时候这个 Annotation 并没有强制要求添加,但是如果添加了 @Override 标记,当你的重写出现
错误的时候,编译器会产生一个错误。
@SuppressWarnings
这个注释会让编译器隐藏特定的警告信息。例如下面的例子中使用了不推荐的方法,因此编译器会产生警告,但是加上了 @SuppressWarnings 注释后,编译器就会隐藏这个警告信息。
// use a deprecated method and tell
// compiler not to generate a warning
@SuppressWarnings("deprecation")
void useDeprecatedMethod() {
// deprecation warning
// - suppressed
objectOne.deprecatedMethod();
}
每个编译器的警告都有特定的分类。Java 语言规范列出了两个分类:deprecation 和 unchecked 分类,想要隐藏多个分类下的警告信息,可以使用下面的语法:
@SuppressWarnings({"unchecked", "deprecation"})
@SafeVarargs
@SafeVarargs 注释只能用于可变长参数的方法或构造方法上,并且方法必须为 final 或 static,否则编译会报错。如果开发者确认可变长参数在使用
泛型类的时候,不会产生潜在的安全问题,那么可以使用这个注释来隐藏编译器的警告信息。
@FunctionalInterface
@FunctionalInterface 是在 Java 8 中引入的新注释,表明被注释的
接口是“函数式接口”。
2、用在 Annotation 上的 Annotation
用于 Annotation 的 Annotation 被称为元 Annotation,它们定义在 java.lang.annotation 包中。
@Retention
被 @Retention 注释的 Annotation 将会被指定存储的方式:
RetentionPolicy.SOURCE 被注释的 Annotation 只存在于源码中,会被编译器忽略。
RetentionPolicy.CLASS 被注释的 Annotation 会被编译器读取,但是会在运行时被虚拟机忽略。
RetentionPolicy.RUNTIME 被注释的 Annotation 在运行时会被虚拟机读取。
@Documented
使用 Java 文档生成工具生成文档的时候,被 @Documented 注释的 Annotation 将会生成文档,默认情况下,Annotation 不会生成文档。
@Target
@Target 将会指定 Annotation 将会被允许使用在哪些 Java 元素上。@Target 可以使用下面的值:
ElementType.ANNOTATION_TYPE 可以用在 Annotation 上。
ElementType.CONSTRUCTOR 可以用在构造方法上。
ElementType.FIELD 可以用在成员变量上。
ElementType.LOCAL_VA
RIABLE 可以用在局部变量上。
ElementType.METHOD 可以用在方法上。
ElementType.PACKAGE 可以用在包声明上。
ElementType.PARAMETER 可以用在方法的参数上。
ElementType.TYPE 可以用在类的任何元素上。
@Inherited
@Inherited 注释的 Annotation 具备继承性(默认是不具备的)。如果 @Inherited 注释的 Annotation 用于某个类上,那么这个类的子类也被继承了父类的 Annotation。
@Repeatable
@Repeatable 是 Java 8 引入的,被 @Repeatable 注释的 Annotation 就是可重复 Annotation,即在同一个 Java 元素上可以使用相同的 Annotation 注释多次。
文章来源:http://www.aptusource.org/2014/03/predefined-annotation-types/