Java
注解是附加在代码中的一些元信息,用于一些工具在编译、运行时进行解析和使用,起到说明、配置的功能。

注解不会也不能影响代码的实际逻辑,仅仅起到辅助性的作用。包含在 java.lang.annotation 包中。
自定义注解中需要包括四个元注解:@Retention @Target @Document @Inherited四种。
1、@Retention: 定义注解的保留策略.
1.1 @Retention(RetentionPolicy.SOURCE) //注解仅存在于源码中,在class字节码文件中不包含
1.2 @Retention(RetentionPolicy.
CLASS)
// 默认的保留策略,注解会在class字节码文件中存在,但运行时无法获得
1.3 @Retention(RetentionPolicy.RUNTIME)
// 在运行时可以通过反射获取到,JVM会读取注解,同时保存在class文件中
2、@Target:定义注解的作用目标
2.1 我这里只用到了ElementType里的field,当然也可以同时有几个。
其中还包括:
@Target(ElementType.TYPE)
//作用于类、接口、枚举,但不能是注解
@Target(ElementType.FIELD)
//作用于
字段、枚举
@Target(ElementType.METHOD)
//作用于
方法、不能是构造方法
@Target(ElementType.PARAMETER)
//作用于
方法的参数
@Target(ElementType.CONSTRUCTOR)
//作用于
构造函数
@Target(ElementType.LOCAL_VARIABLE)
//
局部变量,作用于本地变量或者catch语句
@Target(ElementType.ANNOTATION_TYPE)
//作用于
注解
@Target(ElementType.PACKAGE) /
/作用于
包
3、
@Document:说明该注解将被包含在javadoc中
4、@Inherited:说明子类可以继承父类中的该注解
@interface用于定义注解接口,接口中只能定义成员变量,且定义的成员变量必须以()结尾,可以有default关键字来指定默认值,如果没有default,则在使用注解时必须赋值。
下面是我的例子:
那么注解我们写好了,具体怎么用呢?
1. getAnnotations():返回该程序元素上存在的所有注解。
2. isAnnotationPresent(annotation.class):判断该程序元素上是否包含指定类型的注解
3. getDeclaredAnnotations():返回直接存在于此元素上的所有注释。
测试类:
解析方法的第一种方式,
解析方法的第二种方式