java自定义注解

Java自定义注解的步骤如下123:

  • 使用@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);
        }
    }
}

你可能感兴趣的:(java,开发语言)