`
talentnba
  • 浏览: 93238 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java 中 注解 (Annotations) 学习

    博客分类:
  • Java
阅读更多

注释分为三个基本种类:

  • 标记注释没有变量。注释显示简单,由名称标识,没有提供其他数据。例如, @MarkerAnnotation 是标记注释。它不包含数据,仅有注释名称。
  • 单一值注释与标记注释类似,但提供一段数据。因为仅提供很少的一点数据,所以可以使用快捷语法(假设注释类型接受此语法): @SingleValueAnnotation("my data") 。除了 @ 标记外,这应该与普通的 Java 方法调用很像。
  • 完整注释有多个数据成员。因此,必须使用更完整的语法(注释不再像普通的 Java 方法): @FullAnnotation(var1="data value 1", var2="data value 2", var3="data value 3")

    一个例子如下:

    @TODOItems({    // Curly braces indicate an array of values is being supplied
      @TODO(
        severity=TODO.CRITICAL,
        item="Add functionality to calculate the mean of the student's grades",
        assignedTo="Brett McLaughlin"
      ),
      @TODO(
        severity=TODO.IMPOTANT,
        item="Print usage message to screen if no command-line flags specified",
        assignedTo="Brett McLaughlin"
      ),
      @TODO(
        severity=TODO.LOW,
        item="Roll a new website page with this class's new features",
        assignedTo="Jason Hunter"
      )
    })
    

    Override 注释

    Override 应该仅用于方法(不用于类、包声明或其他构造)。它指明注释的方法将覆盖超类中的方法。eg:

    package quickstart.service;
    import quickstart.model.Person;
    public class PersonServiceImpl implements PersonService {
     @Override
     public void remove(int id) {
             // TODO Auto-generated method stub
     }
     
     @Override
     public void save(Person person) {
      // TODO Auto-generated method stub
     }
    }

    Deprecated 注释

    Deprecated 是标记注释。可以使用 Deprecated 来对不应再使用的方法进行注释。与 Override 不一样的是, Deprecated 应该与正在声明为过时的方法放在同一行中

    package com.oreilly.tiger.ch06;
    public class DeprecatedClass {
      @Deprecated public void doSomething() {
        // some code
      }
      public void doSomethingElse() {
        // This method presumably does what doSomething() does, but better
      }
    }
    SuppressWarnings 注释
    个人理解:编译器在编译时阻止某种类型的Warnings。

    指示应该在注释元素(以及包含在该注释元素中的所有程序元素)中取消显示指定的编译器警告。

    注意,在给定元素中取消显示的警告集是所有包含元素中取消显示的警告的超集。

    例如,如果注释一个类来取消显示某个警告,同时注释一个方法来取消显示另一个警告,那么将在此

    方法中同时取消显示这两个警告。 根据风格不同,程序员应该始终在最里层的嵌套元素上使用此注释,

    在那里使用才有效。如果要在特定的方法中取消显示某个警告,则应该注释该方法而不是注释它的类。

    它实际上是 Tiger 的所有新功能的副功能。例如,以泛型为例;泛型使所有种类的新类型安全操作
    成为可能,特别是当涉及 Java 集合时。然而,因为泛型,当使用集合而 没有 类型安全时,编译器
    将抛出警告。这对于针对 Tiger 的代码有帮助,但它使得为 Java 1.4.x 或更早版本编写代码非
    常麻烦。将不断地收到关于根本无关的事情的警告。如何才能使编译器不给您增添麻烦?
    SupressWarnings 可以解决这个问题。 SupressWarningsOverrideDeprecated 不同,
     具有变量的 — 所以您将单一注释类型与该变量一起使用。可以以值数组来提供变量,
    其中每个值指明要阻止的一种特定警告类型。 例如:
    清单 5. 不是类型安全的 Tiger 代码
    public void nonGenericsMethod() {
      List wordList = new ArrayList();    // no typing information on the List
      wordList.add("foo");                // causes error on list addition
    }
    编译时会有 Warning info.
     
    清单 6 通过使用 SuppressWarnings 注释消除了这种问题。
    @SuppressWarings(value={"unchecked"})
    public void nonGenericsMethod() {
      List wordList = new ArrayList();    // no typing information on the List
      wordList.add("foo");                // causes error on list addition
    }
    仅需要找到警告类型(图 3 中显示为“unchecked”),并将其传送到 SuppressWarnings 中。
     
    SuppressWarnings 中变量的值采用数组,使您可以在同一注释中阻止多个警告。例如, 
    @SuppressWarnings(value={"unchecked", "fallthrough"}) 使用两个值的数组。
    此功能为处理错误提供了非常灵活的方法,无需进行大量的工作。
     
    @SuppressWarings("serial"): 关闭了类或方法级别的编译器警告。
    @SuppressWarings(value={"deprecation"}):的作用就是抑制编译器报deprecation的错。
    @SuppressWarings(value={"deprecation"})只支持一个参数,是数组类型,所以你可以不用加value。
     
    参考文档: http://www-128.ibm.com/developerworks/cn/java/j-annotate2.html
     
    自己写注解,文档很详细,直接拷贝过来。

    Tiger 中的注释,第 2 部分: 定制注释

    Write your own annotations in Java 5

     
     
     
    文档选项
       

    将此页作为电子邮件发送

       

    未显示需要 JavaScript 的文档选项

    <!--START RESERVED FOR FUTURE USE INCLUDE FILES--><!-- this content will be automatically generated across all content areas --><!--END RESERVED FOR FUTURE USE INCLUDE FILES-->

    级别: 初级

    Brett McLaughlin (brett@newInstance.com), 作者/编者, O'Reilly Media, Inc

    2004 年 9 月 01 日

    本系列文章的 第 1 部分介绍了注释 —— J2SE 5.0 中新的元数据工具,并重点讨论了 Tiger 的基本内置注释。一个更强大的相关特性是支持编写自己的注释。本文中,Brett McLauglin 说明了如何创建定制注释,如何用自己的注释注解文档,并进一步定制代码。
    <!--START RESERVED FOR FUTURE USE INCLUDE FILES--><!-- include java script once we verify teams wants to use this and it will work on dbcs and cyrillic characters --><!--END RESERVED FOR FUTURE USE INCLUDE FILES-->

    本系列的第一篇文章 介绍了什么是元数据,元数据的重要性,以及如何使用 J2SE 5.0(也叫做 Tiger)的基本内置注释。如果习惯了这些概念,您可能已经在想,Java 5 提供的三种标准注释也并不是特别健壮,能使用的只有 DeprecatedSuppressWarningsOverride 而已。所幸的是,Tiger 还允许定义自己的注释类型。在本文中,我将通过一些示例引导您掌握这个相对简单的过程。您还将了解如何对自己的注释进行注解,以及这样做的一些好处。我要感谢 O'Reilly Media, Inc.,他们非常慷慨地允许我在本文中使用我关于 Tiger 的书籍的“注释”一章中的代码示例(请参阅 参考资料)。

    定义自己的注释类型

    通过添加了一个小小的语法(Tiger 添加了大量的语法结构),Java 语言支持一种新的类型 —— 注释类型(annotation type)。注释类型看起来很像普通的类,但是有一些特有的性质。最明显的一点是,可以在类中以符号( @ )的形式注释其他 Java 代码。我将一步一步地介绍这个过程。

    @interface 声明

    定义新的注释类型与创建接口有很多类似之处,只不过 interface 关键字之前要有一个 @ 符号。清单 1 中给出的是一个最简单的注释类型的示例: 清单 1. 非常简单的注释类型
    package com.oreilly.tiger.ch06;
    /**
     * Marker annotation to indicate that a method or class
     *   is still in progress.
     */
    public @interface InProgress { }
    

    清单 1 的含义非常明显。如果编译这个注释类型,并确信其位于类路径中,那么您就可以在自己的源代码方法中使用它,以指出某个方法或类仍在处理中,如清单 2 所示:

    清单 2. 使用定制的注释类型
    @com.oreilly.tiger.ch06.InProgress
    public void calculateInterest(float amount, float rate) {
      // Need to finish this method later
    }
    

    清单 1 所示注释类型的使用方法和内置注释类型的使用方法完全相同,只不过要同时使用名称和所在的包来指示定制注释。当然,一般的 Java 规则仍然适用,您可以导入该注释类型,直接使用 @InProgress 引用它。

     
    不要漏掉本系列的另一部分

    一定要阅读本系列文章的“ 第 1 部分”,其中介绍了 Java 5.0 中的注释。

    添加成员


    上面所示的基本用法还远远不够健壮。您一定还记得“第 1 部分”中曾经提到的,注释类型可以有成员变量(请参阅 参考资料)。这一点非常有用,尤其是准备将注释作为更加复杂的元数据,而不仅仅将它作为原始文档使用的时候。代码分析工具喜欢加工大量的信息,定制注释可以提供这类信息。

    注释类型中的数据成员被设置成使用有限的信息进行工作。定义数据成员后不需要分别定义访问和修改的方法。相反,只需要定义一个方法,以成员的名称命名它。数据类型应该是该方法返回值的类型。清单 3 是一个具体的示例,它澄清了一些比较含糊的要求:

    清单 3. 向注释类型添加成员
    package com.oreilly.tiger.ch06;
    /**
     * Annotation type to indicate a task still needs to be
     *   completed.
     */
    public @interface TODO {
      String value();
    }
    

    尽管清单 3 看起来很奇怪,但这是注释类型所要求的格式。清单 3 定义了一个名为 value 的字符串,该注释类型能够接受它。然后,就可以像清单 4 中那样使用注释类型:

    清单 4. 使用带有成员值的注释类型
    @com.oreilly.tiger.ch06.InProgress
    @TODO("Figure out the amount of interest per month")
    public void calculateInterest(float amount, float rate) {
      // Need to finish this method later
    }
    

    这里同样没有多少花样。清单 4 假设已经引入了 com.oreilly.tiger.ch06.TODO ,因此源代码中的注释 需要包名作前缀。此外,需要注意的是,清单 4 中采用了简写的方法:将值 ("Figure out the amount of interest per month") 直接提供给注释,没有指定成员变量名。清单 4 和清单 5 是等价的,后者没有采用简写形式:

    清单 5. 清单 4 的“加长”版
    @com.oreilly.tiger.ch06.InProgress
    @TODO(value="Figure out the amount of interest per month")
    public void calculateInterest(float amount, float rate) {
      // Need to finish this method later
    }
    

    当然作为编码人员,我们都不愿意跟这种“加长”版搅在一起。不过要注意,只有当注释类型只有 一个 成员变量,而且变量名为 value 时,才能使用简写形式。如果不符合这个条件,那么就无法利用这种特性。

    设置默认值


    迄今为止,您已经有了一个很好的起点,但是要做得完美,还有很长的一段路要走。您可能已经想到,下一步就要为注释设置某个默认值。如果您希望用户指定某些值,但是只有这些值与默认值不同的时候才需要指定其他的值,那么设置默认值就是一种很好的办法。清单 6 用另一个定制注释 —— 来自 清单 4TODO 注释类型的一个全功能版本,示范了这个概念及其实现:
    清单 6. 带有默认值的注释类型
    package com.oreilly.tiger.ch06;
    public @interface GroupTODO {
      public enum Severity { CRITICAL, IMPORTANT, TRIVIAL, DOCUMENTATION };
      Severity severity() 
            default Severity.IMPORTANT;
      String item();
      String assignedTo();
      String dateAssigned();
    }
          

    清单 6 中的 GroupTODO 注释类型中添加了几个新的变量。因为该注释类型的成员变量不是一个,所以将一个变量命名为 value 没有任何意义。只要成员变量多于一个,就应该尽可能准确地为其命名。因为不可能从 清单 5所示的简写形式中获益,所以您需要创建虽然稍微有点冗长,但是更容易理解的注释类型。

    清单 6 中出现的另一个新特性是注释类型定义了自己的枚举(枚举,即 enumeration,通常也称为 enums,是 Java 5 的另一个新特性。它并没有多么地不同凡响,对注释类型更是如此)。然后,清单 6 使用新定义的枚举作为一个成员变量的类型。

    最后,再回到我们的主题 —— 默认值。建立默认值的过程非常琐碎,需要在成员声明的后面添加关键字 default ,然后提供默认值。正如您所料,默认值的类型必须与成员变量声明的类型完全相同。同样,这也不是什么火箭科学,只不过是词法上的变异。清单 7 给出了一个具体应用中的 GroupTODO 注释,其中 没有 指定 severity 成员:

    清单 7. 使用默认值
      @com.oreilly.tiger.ch06.InProgress
      @GroupTODO(
        item="Figure out the amount of interest per month",
        assignedTo="Brett McLaughlin",
        dateAssigned="08/04/2004"
      )
      public  void calculateInterest(float amount, float rate) {
        // Need to finish this method later
      }
    

    清单 8 中使用了同一个注释,但这一次给出了 severity 的值:

    清单 8. 改写默认值
      @com.oreilly.tiger.ch06.InProgress
      @GroupTODO(
        severity=GroupTODO.Severity.DOCUMENTATION,
        item="Need to explain how this rather unusual method works",
        assignedTo="Jon Stevens",
        dateAssigned="07/30/2004"
      )
      public  void reallyConfusingMethod(int codePoint) {
        // Really weird code implementation
      }
    





    回页首


    对注释的注释


    结束关于注释的讨论之前(至少在本系列文章中),我想简要地讨论一下注释的注释。第 1 部分中所接触的预定义注释类型都有预定义的目的。但是在编写自己的注释类型时,注释类型的目的并不总是显而易见的。除了基本的文档外,可能还要针对某个特定的成员类型或者一组成员类型编写类型。这就要求您为注释类型提供某种元数据,以便编译器保证按照预期的目的使用注释。

    当然,首先想到的就是 Java 语言选择的元数据形式 —— 注释。您可以使用 4 种预定义的注释类型(称为 元注释)对您的注释进行注释。我将对这 4 种类型分别进行介绍。

    指定目标


    最明显的元注释就是允许何种程序元素具有定义的注释类型。毫不奇怪,这种元注释被称为 Target 。但是在了解如何使用 Target 之前,您还需要认识另一个类,该类被称为 ElementType ,它实际上是一个枚举。这个枚举定义了注释类型可应用的不同程序元素。清单 9 给出了完整的 ElementType 枚举:
    清单 9. ElementType 枚举
    package java.lang.annotation;
    public enum ElementType {
      TYPE,			// Class, interface, or enum (but not annotation)
      FIELD,		// Field (including enumerated values)
      METHOD,		// Method (does not include constructors)
      PARAMETER,		// Method parameter
      CONSTRUCTOR,		// Constructor
      LOCAL_VARIABLE,	// Local variable or catch clause
      ANNOTATION_TYPE,	// Annotation Types (meta-annotations)
      PACKAGE		// Java package
    }
    

    清单 9 中的枚举值意义很明确,您自己可以分析其应用的目标(通过后面的注解)。使用 Target 元注释时,至少要提供这些枚举值中的一个并指出注释的注释可以应用的程序元素。清单 10 说明了 Target 的用法:

    清单 10. 使用 Target 元注释
    package com.oreilly.tiger.ch06;
    import java.lang.annotation.ElementType;
    import java.lang.annotation.Target;
    /**
     * Annotation type to indicate a task still needs to be completed
     */
    @Target({ElementType.TYPE,
             ElementType.METHOD,
             ElementType.CONSTRUCTOR,
             ElementType.ANNOTATION_TYPE})
    public @interface TODO {
      String value();
    }
    

    现在,Java 编译器将把 TODO 应用于类型、方法、构造函数和其他注释类型。这样有助于避免他人误用您的注释类型(或者最好的地方是, 您自己也不会因为疲惫而误用它)。

    设置保持性


    下一个要用到的元注释是 Retention 。这个元注释和 Java 编译器处理注释的注释类型的方式有关。编译器有几种不同选择:
    • 将注释保留在编译后的类文件中,并在第一次加载类时读取它。
    • 将注释保留在编译后的类文件中,但是在运行时忽略它。
    • 按照规定使用注释,但是并不将它保留到编译后的类文件中。

    这三种选项用 java.lang.annotation.RetentionPolicy 枚举表示,如清单 11 所示:

    清单 11. RetentionPolicy 枚举
    package java.lang.annotation;
    public enum RetentionPolicy {
      SOURCE,		// Annotation is discarded by the compiler
      CLASS,		// Annotation is stored in the class file, but ignored by the VM
      RUNTIME		// Annotation is stored in the class file and read by the VM
    }
    

    现在可以看出, Retention 元注释类型使用清单 11 所示的枚举值中的一个作为惟一的参数。可以将该元注释用于您的注释,如清单 12 所示:

    清单 12. 使用 Retention 元注释
    @Retention(RetentionPolicy.SOURCE)
    public @interface SuppressWarnings {
      // annotation type body
    }
    

    如清单 12 所示,这里可以使用简写形式,因为 Retention 只有一个成员变量。如果要将保持性设为 RetentionPolicy.CLASS ,那么什么也不需要做,因为这就是默认行为。

    添加公共文档


    下一个元注释是 Documented 。这个元注释也非常容易理解,部分原因是 Documented 是一个标记注释。您应该还记得第 1 部分中曾经提到,标记注释没有成员变量。 Documented 表示注释应该出现在类的 Javadoc 中。在默认情况下,注释 包括在 Javadoc 中,如果花费大量时间注释一个类、详细说明未完成的工作、正确完成了什么或者描述行为,那么您应该记住这一点。

    清单 13 说明了 Documented 元注释的用法:

    清单 13. 使用 Documented 元注释
    package com.oreilly.tiger.ch06;
    import java.lang.annotation.Documented;
    import java.lang.annotation.Retention;
    import java.lang.annotation.RetentionPolicy;
    /**
     * Marker annotation to indicate that a method or class
     *   is still in progress.
     */
            @Documented
    @Retention(RetentionPolicy.RUNTIME)
    public @interface InProgress { }
          

    Documented 的一个实用技巧是保持性策略。注意,清单 13 中规定注释的保持性(retention)是 RUNTIME ,这是使用 Documented 注释类型所 必需的。Javadoc 使用虚拟机从其类文件(而非源文件)中加载信息。确保 VM 从这些类文件中获得生成 Javadoc 所需信息的惟一方法是将保持性规定为 RetentionPolicy.RUNTIME 。这样,注释就会保留在编译后的类文件中 并且由虚拟机加载,然后 Javadoc 可以从中抽取出来添加到类的 HTML 文档中。

    设置继承


    最后一个元注释 Inherited ,可能是最复杂、使用最少、也最容易造成混淆的一个。这就是说,我们简单地看一看就可以了。

    首先考虑这样一种情况:假设您通过定制的 InProgress 注释标记一个类正在开发之中,这完全没有问题,对吧?这些信息还会出现在 Javadoc 中,只要您正确地应用了 Documented 元注释。现在,假设您要编写一个新类,扩展那个还在开发之中的类,也不难,是不是?但是要记住,那个超类还在开发之中。如果您使用子类,或者查看它的文档,根本没有线索表明还有什么地方没有完成。您本来希望看到 InProgress 注释被带到子类中 —— 因为这是 继承 的 —— 但情况并非如此。您必须使用 Inherited 元注释说明所期望的行为,如清单 14 所示:

    清单 14. 使用 Inherited 元注释
    package com.oreilly.tiger.ch06;
    import java.lang.annotation.Documented;
    import java.lang.annotation.Inherited;
    import java.lang.annotation.Retention;
    import java.lang.annotation.RetentionPolicy;
    /**
     * Marker annotation to indicate that a method or class
     *   is still in progress.
     */
    @Documented
            @Inherited
    @Retention(RetentionPolicy.RUNTIME)
    public @interface InProgress { }
          

    添加 @Inherited 后,您将看到 InProgress 出现在注释类的子类中。当然,您并不希望所有的注释类型都具有这种行为(因此默认值是 继承的)。比如, TODO 注释就不会(也不应该)被传播。但是对于这里示范的情况, Inherited 可能非常有用。





    回页首


    结束语


    现在,您也许已经准备回到 Java 世界为所有的事物编写文档和注释了。这不禁令我回想起人们了解 Javadoc 之后发生的事情。我们都陷入了文档过滥的泥潭,直到有人认识到最好使用 Javadoc 来理清容易混淆的类或者方法。无论用 Javadoc 做了多少文章,也没有人会去看那些易于理解的 getXXX()setXXX() 方法。

    注释也可能出现同样的趋势,虽然不一定到那种程度。经常甚至频繁地使用标准注释类型是一种较好的做法。所有的 Java 5 编译器都支持它们,它们的行为也很容易理解。但是,如果要使用定制注释和元注释,那么就很难保证花费很大力气创建的那些类型在您的开发环境之外还有什么意义。因此要慎重。在合理的情况下使用注释,不要荒谬使用。无论如何,注释都是一种很好的工具,可以在开发过程中提供真正的帮助。



    参考资料

    • 您可以参阅本文在 developerWorks 全球站点上的 英文原文

    • 不要遗漏“ Tiger 中的注释,第 2 部分”,即本系列文章的第 2 部分,研究了定制注释。



    • 开放源代码 XDoclet代码生成引擎支持面向属性的 Java 语言编程。



    • JSR 175,将元数据工具合并到 Java 语言中的规范,处于 Java Community Process 的提议最终草案状态。



    • 访问 Sun 的主页,获取 J2SE 5.0 的所有信息



    • 可以 下载 Tiger并自己试用。



    • John Zukowski 的系列文章 Taming Tiger 以实用的基于技巧的形式讲述了 Java 5.0 的新功能。



    • 由 Brett McLaughlin 和 David Flanagan 撰写的 Java 1.5 Tiger: A Developer's Notebook 一书 (O'Reilly & Associates; 2004),以代码为中心、开发人员友好的形式,讲述了几乎所有的 Tiger 的最新功能 — 包括注释。



    • developerWorksJava 技术专区 可以找到数百篇有关 Java 技术的参考资料。



    • 访问 Developer Bookstore,获得技术书籍的完整列表,其中包括数百本 Java 相关主题的书籍。



    • 是否对无需通常的高成本入口点(entry point)或短期评估许可证的 IBM 测试产品感兴趣? developerWorks Subscription为 WebSphere?、DB2?、Lotus?、Rational? 和 Tivoli? 产品提供了低成本的 12 个月单用户许可证,包括基于 Eclipse 的 WebSphere Studio? IDE,用于开发、测试、评估和展示您的应用程序。




    关于作者

     

    Brett McLaughlin 从 Logo 时代(还记得那个小三角吗?)就开始从事计算机工作。在最近几年里,他已经成为 Java 和 XML 社区最知名的作者和程序员之一。他曾经在 Nextel Communications 实现复杂的企业系统,在 Lutris Technologies 编写应用程序服务器,目前在为 O'Reilly Media, Inc 撰写和编辑 书籍

  • 分享到:
    评论

    相关推荐

      入门级java 注解学习示例代码

      Java注解(Annotation)是Java语言的一个重要特性,它为元数据提供了强大的支持。元数据是一种描述数据的数据,它提供了一种安全的方式,使我们可以在不改变程序代码本身的情况下,向编译器或运行时环境提供额外的...

      Java注解(Annotations)深度解析:增强代码功能与可读性

      Java注解是一种强大的元数据机制,它允许开发者在代码中添加额外的信息,这些信息可以被编译器、运行时环境或其他工具使用。通过自定义注解,开发者可以创建灵活的框架和库,提高代码的可读性和可维护性。随着Java...

      java注解学习与android中使用

      在`annotations学习.md`文件中,可能会包含更多关于注解使用的示例和详细解释,包括如何创建注解、如何在代码中使用它们,以及如何编写注解处理器。`src`目录通常包含项目的源代码,可能有使用注解的实际Android应用...

      java 通过反射获取类上注解,方法上注解,注解里的值及方法参数

      在Java编程中,注解(Annotation)是一种元数据,它提供了在代码中插入信息的方式,这些信息可以被编译器或运行时环境读取。反射(Reflection)是Java的一个强大特性,允许程序在运行时检查类、接口、字段和方法等...

      java自定义注解

      Java自定义注解是Java平台提供的一种元编程机制,它允许程序员在代码中插入特定的标记,这些标记可以在编译时或运行时被处理器解析,从而实现特定的功能。自定义注解可以用来增强代码的可读性,简化代码处理,以及...

      通过Java注解实现安全控制

      在IT行业中,Java注解(Annotations)是一种元数据,它为程序提供了附加信息,这些信息可以被编译器、IDE或运行时环境用来执行各种任务,包括但不限于代码分析、编译时验证、运行时处理等。这篇名为“通过Java注解...

      自定义注解实现伪动态传参的小demo

      在Java编程语言中,注解(Annotations)是一种元数据,用于提供有关代码的信息,这些信息可以被编译器或运行时环境使用。自定义注解是扩展Java功能的强大工具,可以用于实现各种目的,如代码生成、编译时检查、运行...

      Android annotations 注解 使用

      在Android开发中,注解(Annotations)是一种强大的工具,它能帮助我们简化代码,提高代码的可读性和可维护性。Android Annotations库是专门为Android应用设计的一个注解处理框架,它提供了一系列预定义的注解,可以...

      Gradle中如何自定义实现Java注解处理器

      在本篇文章中,我们将深入探讨如何在Gradle项目中自定义实现Java注解处理器。 首先,我们需要了解注解处理器的工作原理。Java的注解处理器是在JDK的`javax.annotation.processing`包中定义的,主要由`Processor`...

      java-annotations,基于jvm的语言的注释。.zip

      通过深入研究"java-annotations"项目,我们可以学习到如何设计和实现自己的注解,以及如何在JVM语言中有效地利用注解进行编程。这不仅可以提升我们的编程技能,还能帮助我们更好地理解和利用Java生态系统的丰富工具...

      Java自定义注解Annotation的使用

      自从JDK 1.5引入了注解这一特性以来,它已经成为Java开发中的一个重要组成部分。注解最初是为了推动EJB 3.0的普及和发展而设计的,其目的是减少配置文件的使用,使得开发变得更加简洁高效。随着时间的推移,这种“零...

      Java中的注解Annotationsnava)1

      Java中的注解(Annotations)是元数据的一种形式,用于向编译器、IDE或运行时环境提供关于代码的额外信息。这些信息可以用于代码验证、简化维护、代码生成以及运行时处理。注解不会直接影响程序的执行,但它们可以被...

      Hibernate Annotations 中文文档

      Hibernate Annotations API 中文文档 前言 1. 创建一个注解项目 1.1. 系统需求 1.2. 系统配置 2. 实体Bean 2.1. 简介 2.2. 用EJB3注解进行映射 2.2.1. 声明实体bean 2.2.1.1. 定义表(Table) 2.2.1.2. 乐观...

      关于java注解比较详细的例子

      Java注解(Annotation)是Java语言的一个重要特性,它为代码提供了一种元数据,用于在编译时或运行时进行处理。注解不会直接影响程序的执行,但可以通过注解处理器来实现特定的功能,例如代码生成、验证、性能监控等...

      Java8新特性之重复注解(repeating annotations)浅析

      Java 8是一个重要的Java版本,它引入了许多新特性和改进,其中之一就是重复注解(repeating annotations)。在Java 8之前,尽管可以使用数组类型的注解来实现类似的效果,但这种方式并不直观,降低了代码的可读性。...

      annotations-1.3.2.jar.zip

      《深入解析Java注解(Annotations)与jar包》 在Java编程中,注解(Annotations)扮演着重要的角色,它们为代码提供了元数据,使得编译器、开发工具以及运行时环境能更好地理解和处理代码。本篇文章将围绕"annotations-...

      sca服务构件架构java通用注解和api规范

      在Java环境中,SCA通过引入特定的注解(Annotations)和API,使得Java开发者能够更方便地参与到服务构件的开发过程中。这些注解和API规范定义了如何声明服务、引用其他服务以及配置服务属性。 1. **注解...

      java 注解annotation的使用以及反射如何获取注解

      Java注解(Annotation)是Java语言提供的一种元数据机制,用于向编译器或JVM提供额外的信息。这些信息可以用来验证代码、控制代码生成、配置应用等。注解是自Java 5版本引入的特性,它使得程序员可以在源代码中嵌入...

      jsoup-annotations是Jsoup注解的POJO

      2. **创建注解的Pojo类**:接着,定义一个Java类,并使用JSoup-Annotations的注解来标注字段。比如,如果你要解析一个包含标题、作者和内容的博客文章,可以创建如下类: ```java public class BlogPost { @Id(...

    Global site tag (gtag.js) - Google Analytics