Java泛型自定义注解参数与默认值

注解参数与默认值

注解参数

每 1个 Annotation 都与 1个 RetentionPolicy 关联,并且与 1~n 个 ElementType 关联

ElementType 关键字:==@Target== 下面为参数说明:

TYPE : 标注"类、接口(包括注释类型)或枚举声明"。
FIELD : 标注"字段声明"。
METHOD : 标注"方法"。
PARAMETER : 标注"参数"。
CONSTRUCTOR : 标注"构造方法"。
LOCAL_VARIABLE : 标注"局部变量"。

RetentionPolicy 关键字:==@Retention== 下面为参数说明:

SOURCE :
Annotation 仅存在于编译器处理期间,编译器处理完之后,该 Annotation 就没用了。
例如," @Override" 标志就是一个 Annotation。当它修饰一个方法的时候,就意味着该方法覆盖父类的方法;并且在编译期间会进行语法检查!编译器处理完后,"@Override" 就没有任何作用了。
CLASS :
编译器将 Annotation 存储于类对应的 .class 文件中,它是 Annotation 的默认行为。
RUNTIME :
编译器将 Annotation 存储于 class 文件中,并且可由JVM读入。

@Deprecated

@Documented
@Retention(RetentionPolicy.RUNTIME)
public @interface Deprecated {
}

说明:

  1. @interface -- 它的用来修饰 Deprecated,意味着 Deprecated 实现了
    java.lang.annotation.Annotation 接口;即 Deprecated 就是一个注解。
  2. @Documented -- 它的作用是说明该注解能出现在 javadoc 中。
  3. @Retention(RetentionPolicy.RUNTIME) -- 它的作用是指定 Deprecated 的策略是
    RetentionPolicy.RUNTIME。这就意味着,编译器会将Deprecated 的信息保留在 .class
    文件中,并且能被虚拟机读取。
  4. @Deprecated 所标注内容,不再被建议使用。

例如:若某个方法被 @Deprecated 标注,则该方法不再被建议使用。如果有开发人员试图使用或重写被 @Deprecated 标示的方法,编译器会给相应的提示信息。

@Inherited

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.ANNOTATION_TYPE)
public @interface Inherited {
}

说明:

  1. @interface -- 它的用来修饰 Inherited,意味着 Inherited 实现了
    java.lang.annotation.Annotation 接口;即 Inherited 就是一个注解。
  2. @Documented -- 它的作用是说明该注解能出现在 javadoc 中。
  3. @Retention(RetentionPolicy.RUNTIME) -- 它的作用是指定 Inherited 的策略是
    RetentionPolicy.RUNTIME。这就意味着,编译器会将 Inherited 的信息保留在 .class
    文件中,并且能被虚拟机读取。
  4. @Target(ElementType.ANNOTATION_TYPE) -- 它的作用是指定 Inherited 的类型是
    ANNOTATION_TYPE。这就意味着,@Inherited 只能被用来标注 "Annotation 类型"。
  5. @Inherited 的含义是,它所标注的Annotation将具有继承性。

例如:我们定义了某个 Annotaion,它的名称是 MyAnnotation,并且 MyAnnotation 被标注为 @Inherited。现在,某个类 Base 使用了
MyAnnotation,则 Base 具有了"具有了注解 MyAnnotation";现在,Sub 继承了 Base,由于 MyAnnotation 是 @Inherited的(具有继承性),所以,Sub 也 "具有了注解 MyAnnotation"。

@SuppressWarnings

@Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE})
@Retention(RetentionPolicy.SOURCE)
public @interface SuppressWarnings {
    String[] value();
}

说明:

  1. @interface -- 它的用来修饰 SuppressWarnings,意味着 SuppressWarnings 实现了
    java.lang.annotation.Annotation 接口;即 SuppressWarnings 就是一个注解。
  2. @Retention(RetentionPolicy.SOURCE) -- 它的作用是指定 SuppressWarnings 的策略是
    RetentionPolicy.SOURCE。这就意味着,SuppressWarnings 信息仅存在于编译器处理期间,编译器处理完之后
    SuppressWarnings 就没有作用了。
  3. @Target({TYPE, FIELD, METHOD, PARAMETER, CONSTRUCTOR,
    LOCAL_VARIABLE}) -- 它的作用是指定 SuppressWarnings 的类型同时包括TYPE, FIELD,
    METHOD, PARAMETER, CONSTRUCTOR, LOCAL_VARIABLE。
  4. String[] value(); 意味着,SuppressWarnings 能指定参数
  5. SuppressWarnings 的作用是,让编译器对"它所标注的内容"的某些警告保持静默。

例如:"@SuppressWarnings(value={"deprecation", "unchecked"})" 表示对"它所标注的内容"中的 "SuppressWarnings 不再建议使用警告"和"未检查的转换时的警告"保持沉默。

补充:SuppressWarnings 常用的关键字

deprecation  -- 使用了不赞成使用的类或方法时的警告
unchecked    -- 执行了未检查的转换时的警告,例如当使用集合时没有用泛型 (Generics) 来指定集合保存的类型。
fallthrough  -- 当 Switch 程序块直接通往下一种情况而没有 Break 时的警告。
path         -- 在类路径、源文件路径等中有不存在的路径时的警告。
serial       -- 当在可序列化的类上缺少 serialVersionUID 定义时的警告。
finally      -- 任何 finally 子句不能正常完成时的警告。
all          -- 关于以上所有情况的警告。

默认值

自定义注解时使用以下语法定义默认值:

public @interface MyAnnotation {
    String value() default "默认值";
}

键字 default 指定默认值。

默认值必须是与元素的数据类型兼容的类型。

以下代码通过将其minor元素的默认值指定为零来创建Version注释类型,如下所示:

public  @interface  Version {
    int major();
    int minor() default 0; 
}

例子

以下代码显示如何使用默认值使用注释。

@Version(major=1) // 这里没有指定minor 所有这里的使用的时默认值0
@Version(major=2, minor=1) // 

以下代码显示如何为数组和其他数据类型指定默认值:

public @interface Version {
  double d() default 1.89;

  int num() default 1;

  int[] x() default { 1, 2 };

  String s() default "Hello";

  String[] s2() default { "abc", "xyz" };

  Class c() default Exception.class;

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

推荐阅读更多精彩内容