【Java SE】Annotation

1# Annotation

Provides library support for the Java programming language annotation facility.

2# Key Class

2.1# java.lang

  • @Override
    Indicates that a method declaration is intended to override a method declaration in a supertype.
  • @Deprecated
    A program element annotated @Deprecated is one that programmers are discouraged from using, typically because it is dangerous, or because a better alternative exists.
    values:deprecation,unchecked,fallthrough,path,serial,finally,all
  • @SuppressWarnings
    Indicates that the named compiler warnings should be suppressed in the annotated element (and in all program elements contained in the annotated element).
  • @SafeVarargs (since 1.7)
    A programmer assertion that the body of the annotated method or constructor does not perform potentially unsafe operations on its varargs parameter.
  • @FunctionalInterface (since 1.8)
    An informative annotation type used to indicate that an interface type declaration is intended to be a functional interface as defined by the Java Language Specification.

2.2# java.lang.Annotation | Annotation Types

  • @Target
    Indicates the contexts in which an annotation type is applicable.
  • @Relention
    Indicates how long annotations with the annotated type are to be retained.
  • @Documented
    Indicates that annotations with a type are to be documented by javadoc and similar tools by default.
  • @Inherited
    Indicates that an annotation type is automatically inherited.
  • @Native (since 1.8)
    Indicates that a field defining a constant value may be referenced from native code.
  • @Repeatable (since 1.8)
    The annotation type java.lang.annotation.Repeatable is used to indicate that the annotation type whose declaration it (meta-)annotates is repeatable.

2.2# java.lang.Annotation | Enum

  • ElementType
    • TYPE:Class, interface (including annotation type), or enum declaration
    • FIELD:Field declaration (includes enum constants)
    • METHOD:Method declaration
    • PARAMETER:Formal parameter declaration
    • CONSTRUCTOR:Constructor declaration
    • LOCAL_VARIABLE:Local variable declaration
    • ANNOTATION_TYPE:Annotation type declaration
    • PACKAGE:Package declaration
    • TYPE_PARAMETER:Type parameter declaration
    • TYPE_USE:Use of a type
  • RetentionPolicy
    表示需要在什么级别保存该注释信息,用于描述注解的生命周期(即:被描述的注解在什么范围内有效)
    • SOURCE:Annotations are to be discarded by the compiler.在源文件中有效(即源文件保留)
    • CLASS:Annotations are to be recorded in the class file by the compiler but need not be retained by the VM at run time.在class文件中有效(即class保留)
    • RUNTIME:Annotations are to be recorded in the class file by the compiler and retained by the VM at run time, so they may be read reflectively.在运行时有效(即运行时保留)

3# Common Annotation Class

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Target {
    ElementType[] value();
}
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Retention {
    RetentionPolicy value();
}
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Documented {
}

4# Annotation Elements Returns

  • int,float,boolean,byte,double,char,long,short
  • String
  • Class
  • enum
  • Annotation
  • Array type all of above
    PS. You can use 'default ' to statement the default value the element returns

5# Custom Annotation

5.1# Annotation Class

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface Robot {
    public enum RobotSize {BIG, MED, MIN;}
    int robotcount() default 1;
    String robotName() default "ET";
    RobotSize robotSize() default RobotSize.MED;
}

5.2# applied to a method

@Robot(robotcount = 5, robotName = "XMAN", robotSize = Robot.RobotSize.BIG)
    public void buildRobot() {}

5.3# get the annotation info by reflection

public class RobotBuilder {
    public static void main(String[] args) {
        getAnnotationInfo(RobotBuilder.class);
    }

    private static void getAnnotationInfo(Class<RobotBuilder> robotBuilderClass) {
        Method[] methods = robotBuilderClass.getDeclaredMethods();
        for (Method method : methods) {
            Robot annotation = method.getAnnotation(Robot.class);
            if (annotation != null) {
                int robotcount = annotation.robotcount();
                String robotName = annotation.robotName();
                Robot.RobotSize robotSize = annotation.robotSize();
                System.out.println(">>>robotcount:"+robotcount);
                System.out.println(">>>robotName:"+robotName);
                System.out.println(">>>robotSize:"+robotSize);
            }
        }
    }

    @Robot(robotcount = 5, robotName = "XMAN", robotSize = Robot.RobotSize.BIG)
    public void buildRobot() {}
}

output

>>>robotcount:5
>>>robotName:XMAN
>>>robotSize:BIG
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,052评论 6 513
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,267评论 3 397
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 167,518评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,457评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,474评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,143评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,728评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,650评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,184评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,269评论 3 339
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,415评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,083评论 5 348
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,775评论 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,257评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,389评论 1 271
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,777评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,419评论 2 359

推荐阅读更多精彩内容