在现在的开发中,注解越来越多地应用到了开发中,无论是Servlet3.0新特性,还是SSH中的全注解,都给开发带来了极大的便利, 直观. 因此需要对注解有深入的理解.
一. 自定义注解
自定义注解的目标:原来写在配置文件中的信息,可以通过注解描述
带默认值的方式:String name() default “xxx”
以上类型的一维数组
二. JDK 的元 Annotation
2.1 元 Annotation指修饰Annotation的Annotation
JDK中定义了如下元Annotation:
@Retention: 只能用于修饰一个 Annotation 定义, 用于指定该 Annotation 可以保留的域, @Rentention 包含一个 RetentionPolicy 类型的成员变量, 通过这个变量指定域。RetentionPolicy.SOURCE: 编译器直接丢弃这种策略的注释
2.2
@Target:指定注解用于修饰类的哪个成员. @Target 包含了一个名为 value,类型为ElementType的成员变量。
@Documented: 用于指定被该元 Annotation 修饰的 Annotation 类将被 javadoc 工具提取成文档.
@Inherited: 被它修饰的 Annotation 将具有继承性.如果某个类使用了被 @Inherited 修饰的 Annotation, 则其子类将自动具有该注解
三. 解析Annotation 信息
JDK 5.0 在 java.lang.reflect 包下新增了 Annotation 接口, 该接口代表程序中可以接受注解。
当一个 Annotation 类型被定义为运行时 Annotation 后, 该注释才是运行时可见, 当 class 文件被载入时保存在 class 文件中的 Annotation 才会被虚拟机读取
程序可以调用 AnnotationElement 对象的如下方法来访问 Annotation 信息:
四. 使用xml文件还是使用注解进行实际开发:
需要根据实际开发的需求,如果考虑到项目的扩展性,需要使用XML文件. 若是考虑到开发项目时的便捷,应使用注解.
利与弊:
1. xml文档 改动配置不需要重新编译java类. 但XML文档往往过大,配置繁琐不直观,容易打断开发人员思路
2.注解简单,便捷,直观. 但是改动配置时需要将java类重新编译
实际开发中可衡量XML文件和注解的利与弊进行选择.