- 使用@interface关键字定义注解,注解的成员参数只能是基本类型、String、Class、Enum、Annotation或者它们的数组。
- 使用元注解@Target、@Retention、@Documented、@Inherited、@Repeatable来修饰自定义注解,指定注解的作用目标、生命周期、文档生成、继承性和重复性等属性。
- 使用反射API来获取注解信息,并根据注解的逻辑进行相应的处理。
例如,下面是一个自定义注解的例子,用来给类或方法添加描述信息4:
// 定义一个名为Description的注解
@Target({ElementType.TYPE, ElementType.METHOD}) // 作用于类和方法
@Retention(RetentionPolicy.RUNTIME) // 运行时有效
@Documented // 生成文档
public @interface Description {
// 定义一个名为value的成员参数,类型为String,默认值为空
String value() default "";
}
// 使用Description注解来修饰一个类和方法
@Description("这是一个人类")
public class Person {
@Description("这是一个说话的方法")
public void speak() {
System.out.println("Hello");
}
}
// 使用反射API来获取注解信息并打印
public class Test {
public static void main(String[] args) throws Exception {
// 获取Person类的Class对象
Class<?> clazz = Person.class;
// 判断是否有Description注解
if (clazz.isAnnotationPresent(Description.class)) {
// 获取Description注解对象
Description desc = clazz.getAnnotation(Description.class);
// 获取注解的值
String value = desc.value();
// 打印结果
System.out.println("类的描述:" + value);
}
// 获取Person类的speak方法对象
Method method = clazz.getMethod("speak");
// 判断是否有Description注解
if (method.isAnnotationPresent(Description.class)) {
// 获取Description注解对象
Description desc = method.getAnnotation(Description.class);
// 获取注解的值
String value = desc.value();
// 打印结果
System.out.println("方法的描述:" + value);
}
}
}