Java注解的一点记录

注解的崛起

曾几何时java项目相关的配置都是xml的天下,不管是jdbc、事物处理还是spring bean。但是随着项目越来越大,会发现维护这些xml会相当费劲,当你想将新加的class交给DI容器时就会显得很繁琐。

自定义注解

可以通过自定义注解,给程序添加额外的功能,使得原先的一些繁琐的事情变得简单。

  1. 新建一个注解语法比较简单
public void @interface MyAnnotation{
    FeildType feildName default defaultValue; // 定义相关字段
}
  1. 给自定义注解加上元注解
@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实现的。

  1. 通过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");
    }
}

转载于:https://my.oschina.net/u/1187203/blog/1816839

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值