zoukankan      html  css  js  c++  java
  • Core Java Volume II—Using annotations

    Annotations are tags that you insert into your source code so that some tool can process them. The tools can operate on source level or they can process class files into which the compiler has placed annotations.

    Uses for annotations:

    • Automatic generation of auxiliary files such as deployment descriptors or bean information classes
    • Automatic generation of code for testing, logging, transaction semantics, and so on

    Junit 4 testing tool calls all methods that are labeled @test when testing a class.

    Annotations can be defined to have elements which can be processed by the tools that read the annotations.

    An annotation can be put anywhere that you could put a modifier.

    You can annotate packages, parameter variables, type parameters, and type uses.

    Each annotation must be defined by an annotation interface. The methods of the interface correspond to the elements of the annotation.

    The @interface declaration creates an actual Java interface.

    Annotation Syntax:

    An annotation is defined by a annotation interface:

    modifiers @interface AnnotationName{
        elementDeclaration1;
        elementDeclaration2;
        …
    }

    Each element declaration has the form

    type elementName();

    or

    type elementName() default value;

    You cannot extend annotation interfaces.

    The type of an annotation element is one of the following:

    • A primitive type
    • String
    • Class
    • An enum type
    • An annotation type
    • An array of the preceding types(an array of arrays is not a legal element type)

    Each element has the format

    @AnnotationName(elementName1 = value1, elementName2 = value2, …) // the order of elements does not matter.

    The default value of the declaration is used if an element value is not specified.

    If no elements are specified, you don't need to use parentheses.

    @AnnotationName

    The single value annotation

    If an element has the special name value and no other element is specified, you can omit the element name and the = symbol.

    An item can have multiple annotations, if an annotation is repeatable, you can repeat same annotation multiple times.

    An annotation element can never be set to null. You can find other defaults such as "" or Void.class.

    2 main use of annotation: declarations and type uses.

    Declaration annotations can appear at the declaration of:

    • Packages
    • Classes
    • Interfaces
    • Methods
    • Constructors
    • Instances fields (including enum constants)
    • Local variables
    • Parameter variables
    • Type parameters

    For classes and interfaces, put the annotations before the class or interface keyword; for variables, put them before the type; for type parameters <@AnnotationName V>; for packages, the package-info.java contains only the package statement preceded by annotations.

    Type use annotations can appear in the following places:

    • With generic type arguments
    • In any position of an array
    • With superclasses and implemented interfaces:
    • With constructor invocations
    • With instanceof checks and casts
    • With exception specifications
    • With method and constructor references: eg. @Annotation Message::getText

    Custom:

    • Put type use annotations after other modifiers;
    • Put declaration annotations before other modifiers.

    An annotation placed on the constructor describes a property of the constructed object.

    Annotation

    Purpose

    @Generated

    Code generator tools

    @PostConstruct

    @PreDestroy

    In environments that control the life-circle of objects—methods tagged with these annotations should be invoked immediately after an object has been constructed or before is being removed.

    @Resource

    Resource injection

    @Target({ElementType.X, ElementType.Y, …})

    Apply to an annotation, retricting the items to which the annotation applies.

    @Rentention

    Specifies how long an annotation is retained (SOURCE, CLASS, RUNTIME).

    @Documented

    The documentation of each annotated method/… contains the annotation.

    @Inherited

    Only applies to classes, all of the subclasses automatically have the same annotation.

    Java SE 8 -> Legal to apply the same annotation type multiple times to an item. For backward compatibility, the implementor of a repeatable annotation needs to provide a container annotation that holds the repeated annotations in an array.

    Whenever the user supplies 2 or more @TestCase annotations, they are automatically wrapped into a @TestCases annotation.

  • 相关阅读:
    struts.xml,报错 1 c.opensymphony.xwork2.util.DomHelper
    poi 导入Excle
    Oracle update语句更新值来自另一张表中的数据
    Oracle 《积累章》 根据身份证号码更新当前出生日期
    java 反射得到属性与属性值
    spring mvc 简单的文件上传与下载
    java扫描文件。
    类加载机制
    容器工厂(原型&单例)
    容器工厂(原型)
  • 原文地址:https://www.cnblogs.com/Hu-Yan/p/8977892.html
Copyright © 2011-2022 走看看