Java 注解(Annotation)是 JDK 5.0 引入的一种元数据,用于将某些信息与代码关联起来。注解可以应用于类、方法、变量、参数和包等元素上,用于提供额外的信息或元数据,以便于编译器、开发工具和运行时环境使用。
Java 注解的基本语法如下:
@annotationName(value1, value2, ..., valueN)
其中,annotationName 是注解的名称,value1, value2, …, valueN 是注解的属性值,可以有多个属性值。
Java 中内置了一些注解,如 @Override、@Deprecated 等。同时,也可以自定义注解。自定义注解需要使用 @interface 关键字来定义,可以定义注解的名称、属性和属性值类型等信息。
注解生命周期有三大类,分别是:
● RetentionPolicy.SOURCE:给编译器用的,不会写入 class 文件
● RetentionPolicy.CLASS:会写入 class 文件,在类加载阶段丢弃,也就是运行的 时候就没这个信息
● RetentionPolicy.RUNTIME:会写入 class 文件,永久保存,可以通过反射获取注 解信息
以下是一个简单的自定义注解示例:
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD) // 作用位置
public @interface MyAnnotation {
String value() default "";
int count() default 0;
}
这个注解可以用于方法上,具有两个属性 value 和 count,分别默认为空字符串和 0。使用 @Retention 和 @Target 注解可以指定注解的保留策略和作用目标。在这个示例中,@Retention 指定了注解的保留策略为 RUNTIME,表示注解在运行时仍然可用;
@Target 指定了注解的作用目标为 METHOD,表示注解只能应用于方法上。
使用自定义注解时,可以在代码中使用 @annotationName 语法来应用注解,并在代码中使用注解的属性值来访问注解的属性。例如:
@MyAnnotation(value = "hello", count = 3)
public void myMethod() {
// do something
}
在这个示例中,@MyAnnotation 注解被应用于 myMethod 方法上,并设置了 value 属性为 “hello”,count 属性为 3。在代码中可以使用 MyAnnotation 注解的属性值来访问这些属性。
再比如 Spring 常见的 Autowired ,就是 RUNTIME 的,所以在运行的时候可以通 过反射得到注解的信息,还能拿到标记的值 required 。