java 注解的几大作用及使用方法详解(完)

时间:2017-11-28 14:41

第二个元注解: @Retention 参数 RetentionPolicy。有了前面的经验这个注解理解起来就简单多了,并且幸运的是这个注解还没有特殊的属性值。 简单演示下如何使用:


package com.tmser.annotation; import java.lang.annotation.ElementType; import java.lang.annotation.Target; /* * 定义注解 Test * 首先使用ElementType.TYPE * 运行级别定为 运行时,以便后面测试解析  */ @Target(ElementType.PACKAGE)

@Retention(RetentionPolicy.RUNTIME)

public @interface TestA { }

第三和第四个元注解就不再举例了。比较简单,也没有值,相信看过上面的解释也就清楚了。下面我们还是继续来深入的探讨下注解的使用。上面的例子都非常简单,注解连属性都没有。ok,下面我们就来定义一个有属性的注解,并在例子程序中获取都注解中定义的值。

开始之前将下定义属性的规则:

        @interface用来声明一个注解,其中的每一个方法实际上是声明了一个配置参数。方法的名称就是参数的名称,返回值类型就是参数的类型(返回值类型只能是基本类型、Class、String、enum)。可以通过default来声明参数的默认值。

代码:


/* * 定义注解 Test * 为方便测试:注解目标为类 方法,属性及构造方法 * 注解中含有三个元素 id ,name和 gid; * id 元素 有默认值 0 */ @Target({TYPE,METHOD,FIELD,CONSTRUCTOR}) @Retention(RetentionPolicy.RUNTIME) public @interface TestA { String name(); int id() default 0; Class<Long> gid(); }