注解是代码的附属信息,它遵循一个基本原则:注解不能直接干扰程序代码的运行,无论增加或删除注解,代码都能正常运行。java语言解释器会忽略这些注解,而由第三方工具 负责对注解进行处理。第三方工具可以利用代码中的注解间接控制程序代码的运行,它们通过java反射机制读取注解的信息,并根据这些信息更改目标程序的逻辑,而这就是SpringAOP对@AspectJ提供支持所采取的方法。
定义注解:
@Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface NeedTest { boolean value() default true; String description()default "LOW"; }
注解的限制:
1.成员以无入参无抛出异常的方式声明。
2.可以通过default为成员指定一个默认值。
3.成员类型是受限的,合法的类型包括原始类型和封装类型。
@Retention表示NeedTest这个注解的保留期限。
Retention.SOURCE 注解将被编译器丢弃,只保存在源码中。
Retention.CLASS 注解在class文件中可用,但类加载器加载字节码文件时不会将注解加载到JVM中,也即运行期不能获取注解信息。
Retention.RUNTIME 将在运行期间保留注解,因此可以通过反射机制读取注解的信息。
@Target注解表示这个注解的应用目标
CONSTRUCTOR:构造器的声明
FIELD:域声明(包括enum实例)
LOCAL_VARIABLE:局部变量声明
METHOD:方法声明
PACKAGE:包声明
PARAMETER:参数声明
TYPE:类、接口(包括注解类型)或enum声明
使用注解:
public class ForumService { @NeedTest(value = true) public void deleteForumById(int fornmId){ System.out.println("delte forum "+fornmId); } }
获取注解:
Class classz = ForumService.class; Method[]methods = classz.getDeclaredMethods(); for (Method method:methods) { NeedTest needTest = method.getAnnotation(NeedTest.class); if(needTest!=null) { if(needTest.value() == true) { System.out.println(method.getName()+"() need Test"); } else { System.out.println(method.getName()+"() no need Test"); } } }