当前位置: 首页 > 编程笔记 >

Java注解之Retention、Documented、Inherited介绍

充昌勋
2023-03-14
本文向大家介绍Java注解之Retention、Documented、Inherited介绍,包括了Java注解之Retention、Documented、Inherited介绍的使用技巧和注意事项,需要的朋友参考一下

Retention注解

Retention(保留)注解说明,这种类型的注解会被保留到那个阶段. 有三个值:
1.RetentionPolicy.SOURCE —— 这种类型的Annotations只在源代码级别保留,编译时就会被忽略
2.RetentionPolicy.CLASS —— 这种类型的Annotations编译时被保留,在class文件中存在,但JVM将会忽略
3.RetentionPolicy.RUNTIME —— 这种类型的Annotations将被JVM保留,所以他们能在运行时被JVM或其他使用反射机制的代码所读取和使用.
示例5演示了 RetentionPolicy.RUNTIME 的声明:

Java注解的示例1:


@Retention(RetentionPolicy.RUNTIME)

public @interface Test_Retention {

   String doTestRetention();

}

在这个示例中, @Retention(RetentionPolicy.RUNTIME)注解表明 Test_Retention注解将会由虚拟机保留,以便它可以在运行时通过反射读取.

Documented 注解

Documented 注解表明这个注解应该被 javadoc工具记录. 默认情况下,javadoc是不包括注解的. 但如果声明注解时指定了 @Documented,则它会被 javadoc 之类的工具处理, 所以注解类型信息也会被包括在生成的文档中. 示例6进一步演示了使用 @Documented:

Java注解的示例2:


@Documented

public @interface Test_Documented {

   String doTestDocument();

}

接下来,像下面这样修改TestAnnotations类:


public class TestAnnotations {

   public static void main(String arg[]) {

      new TestAnnotations().doSomeTestRetention();

      new TestAnnotations().doSomeTestDocumented();

   }

   @Test_Retention (doTestRetention="保留注解信息测试")

   public void doSomeTestRetention() {

      System.out.printf("测试注解类型 'Retention'");

   }

   @Test_Documented(doTestDocument="Hello document")

   public void doSomeTestDocumented() {

      System.out.printf("测试注解类型 'Documented'");

   }

}

现在,如果你使用 javadoc命令生成 TestAnnotations.html文件,你将看到类似于图1的结果.

从截图可以看到,文档中没有 doSomeTestRetention() 方法的 annotation-type信息()方法. 但是, doSomeTestDocumented() 方法的文档提供了注解的描述信息. 这是因为 @Documented标签被加到了Test_Documented注解上. 之前的注解Test_Retention并没有指定 @Documented 标记(tag).

Inherited 注解(这段可能有问题...)

这是一个稍微复杂的注解类型. 它指明被注解的类会自动继承. 更具体地说,如果定义注解时使用了 @Inherited 标记,然后用定义的注解来标注另一个父类, 父类又有一个子类(subclass),则父类的所有属性将被继承到它的子类中. 在示例7中,你会看到使用 @Inherited 标签的好处.

Java注解的示例3

首先,定义你的注解:


@Inherited

public @interface MyParentObject { 

      boolean isInherited() default true;

      String doSomething() default "Do what?";

}

接下来,使用注解标注了一个类:


@MyParentObject

public Class MyChildObject {

}

正如你看到的,你不需要在实现类中定义接口方法. 因为使用 @Inherited标记,这些都自动继承了. 如果你使用一种古老的方式定义实现类,会是什么样子呢? 看看下面这张 古老的实现方式吧:


public class MyChildObject implements MyParentObject {

   public boolean isInherited() {

      return false;

   }

   public String doSomething() {

      return "";

   }

   public boolean equals(Object obj) {

      return false;

   }

   public int hashCode() {

      return 0;

   }

   public String toString() {

      return "";

   }

   public Class annotationType() {

      return null;

   }

}

看到的区别吗? 可以看到,你必须实现父接口的所有方法. 除了isInherited()和从myParentObject doSomething()方法外,你还需要实现 java.lang.Object的 equals(),toString()和hasCode()方法. 还有 java.lang.annotation.Annotation 类的 annotationType()方法. 不管你是不是想要实现这些方法,你必须在继承的对象中包含这些.

结论

本文向你展示了如何通过使用JDK5的注解功能使开发更容易. 注解不直接影响程序的语义. 开发和部署工具可以以某种方式阅读这些注解并处理它们,使用包含注解的程序可以替代额外的Java源文件、XML文档或其他古老的构件.  使用注解可以使用更少的代码完成同样的事情,并且有更好的编译时错误检测机制. 注解的目的是花更少的时间在那些死硬无用的细节中,更多地关注业务逻辑规则. 本文是Java注解系列的第一部分. 在第二部分中,你将了解如何使用注解来开发一个简单的Web应用程序. 最后,在第三部分中,你会看到一个包括多个数据库表的复杂示例.

 类似资料:
  • 问题内容: Java 中注释的目的是什么? 我看了文档,但从中得不到很多。有人可以借助一个明确的例子指出 问题答案: 是一个元注释。您在定义注释时应用,以确保使用注释的类在其生成的JavaDoc中显示此内容。我没有看到太多使用它,但是这里有一个例子。一个更早的问题表明它不能在Eclipse中自动运行,但是我已经在Eclipse 3.6中进行了测试,并且无论是否将注释附加到JavaDoc弹出窗口中,

  • 问题内容: 我没有用Java 获得注释。如果它自动为您继承方法,那么如果我需要以自己的方式实现该方法,那又如何呢? 怎么知道我的实现方式? 另外,据说如果我不想使用它,而是以一种老式的Java方式执行它,则必须实现类的,和方法以及类的注释类型方法。 这是为什么? 即使我不知道注释和以前运行良好的程序,我也从未实现过。 请有人从头开始向我解释一下。 问题答案: 只是没有误会:您确实要询问java.l

  • 我没有得到Java中继承的

  • 本文向大家介绍Java注解详细介绍,包括了Java注解详细介绍的使用技巧和注意事项,需要的朋友参考一下 Java注解介绍 基于注解(Annotation-based)的Java开发无疑是最新的开发趋势.[译者注: 这是05年的文章,在2014年,毫无疑问,多人合作的开发,使用注解变成很好的合作方式,相互之间的影响和耦合可以很低]. 基于注解的开发将Java开发人员从繁琐笨重的配置文件中解脱出来.

  • 本小节我们将学习 Java5 引入的一种机制 —— 注解(Annotation)。通过本小节的学习,你将了解什么是注解,注解的作用,Java 中内置注解有哪些以及注解的分类,如何自定义注解,如何处理注解等内容。 1. 什么是注解 Java 注解(Annotation)又称为 Java 标注,是 Java5开始支持加入源代码的特殊语法元数据。Java 语言中的类、方法、变量、参数和包等都可以被标注。

  • 本文向大家介绍Java基础教程之理解Annotation详细介绍,包括了Java基础教程之理解Annotation详细介绍的使用技巧和注意事项,需要的朋友参考一下 Java基础之理解Annotation 一、概念    Annontation是Java5开始引入的新特征。中文名称一般叫注解。它提供了一种安全的类似注释的机制,用来将任何的信息或元数据(metadata)与程序元素(类、方法、成员变量