java自定义注解的简单示例
为了给方法(或者变量)增加描述,我们通常会自定义注解,以下是一个方法自定义注解的示例。
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.lang.reflect.Method;
@Retention(RetentionPolicy.RUNTIME) // 表示该注解在运行时可见,可以通过反射读取。
@Target(ElementType.METHOD) // 表示该注解可以应用在方法上。
@interface MyAnnotation {
String value() default "";
int count() default 1;
}
在这个示例中,我们创建了一个名为 MyAnnotation 的自定义注解。该注解具有两个成员变量 value 和 count ,并分别使用 default 关键字设置了默认值。
class MyClass {
@MyAnnotation(value = "Hello", count = 3)
public void myMethod() {
// 方法体
}
}
在这个示例中,我们在 myMethod() 方法上使用了 @MyAnnotation 注解,并设置了对应的值。
public class AnnotationMain {
public static void main(String[] args) {
MyClass obj = new MyClass();
Class<?> cls = obj.getClass();
Method[] methods = cls.getDeclaredMethods();
for (Method method : methods) {
if (method.isAnnotationPresent(MyAnnotation.class)) {
MyAnnotation annotation = method.getAnnotation(MyAnnotation.class);
String value = annotation.value();
int count = annotation.count();
System.out.println("Value: " + value + ", Count: " + count);
}
}
}
}
在 Main 类中,我们使用反射获取 MyClass 类的信息,并遍历类中的方法。通过 isAnnotationPresent() 方法判断方法是否应用了 MyAnnotation 注解,如果应用了,则使用 getAnnotation() 方法获取注解的实例,然后可以读取注解的成员变量值。
执行结果:
Value: Hello, Count: 3
Process finished with exit code 0
注意:自定义注解只是一种标记,它本身不会触发任何特定行为。我们可以通过反射机制读取注解信息,并根据注解的值进行相应的处理。