Java 中的预定义 Annotation 类型_JAVA_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > JAVA > Java 中的预定义 Annotation 类型

Java 中的预定义 Annotation 类型

 2014/3/26 6:59:57  cucaracha  程序员俱乐部  我要评论(0)
  • 摘要:在JavaSEAPI中预定义了一系列Annotation。有的用于Java编译器,有的用于Annotation。1、用于编译器的Annotation定义在java.lang包中的@Deprecated@Override和@SuppressWarnings注释。@Deprecated@Deprecated用来标记某个元素不赞成使用。如果应用程序使用的类、方法或字段上添加了@Deprecated,那么如果在程序中使用了被注释的元素,编译器将会生成警告信息
  • 标签:not Java Annotation
在 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_VARIABLE 可以用在局部变量上。
    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/
发表评论
用户名: 匿名