注解的崛起
曾几何时java项目相关的配置都是xml的天下,不管是jdbc、事物处理还是spring bean。但是随着项目越来越大,会发现维护这些xml会相当费劲,当你想将新加的class交给DI容器时就会显得很繁琐。
自定义注解
可以通过自定义注解,给程序添加额外的功能,使得原先的一些繁琐的事情变得简单。
- 新建一个注解语法比较简单
public void @interface MyAnnotation{
FeildType feildName default defaultValue; // 定义相关字段
}
- 给自定义注解加上元注解
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public void @interface MyAnnotation{
FeildType feildName() default defaultValue; // 定义相关字段
}
jdk1.5定义了4个元注解,为自定义的注解添加额外语义
- Target
声明在哪里可以使用该注解,ElementType定义了相关的枚举,如METHOD(只能作用于方法上),默认都可以使用。
- Retention
注解保留的时间,RetentionPolicy定义了相关枚举。
1. RetentionPolicy.CLASS,编译期内有效。
2. RetentionPolicy.RUNTIME,运行期内有效,可以通过反射获取相关数据。
3. RetentionPolicy.SOURCE,编译后失效,注解会被编译期丢弃。
- Documented
将注解交给JavaDoc,可以用相关的工具类生成API。
- Inherited
@Inherited
public void @interface MyAnnotation{
String name() default "test";
}
当一个类使用了MyAnnotation注解时,其子类将会继承该注解,即子类也会被该注解标记。当一个程序试图查找该注解时会一层层往上找,当到达Object类或者找到该注解。
实现注解语义
注解只是一种标记,只有实现注解的语义,才能真正发挥一个注解的作用。如上述提到的4个元注解的语义是由JVM实现的。
- 通过AOP实现注解语义。
@Component
@Aspect
public class AnnotationAspect{
@Around("@annotation(com.test.MyAnnotation)")
public void around(ProceedingJoinPoint pjp){
System.out.println("aspect start");
pjp.proceed();
System.out.println("aspect end");
}
}