一,Annotation(注解) 概述
,Annotation 其实就是代码里的特殊标记, 它用于替代配置文件,也就是说,传统方式通过配置文件告诉类如何运行,有了注解技术后,开发人员可以通过注解告诉类如何运行
三个基本的 Annotation:
•@Override: 限定重写父类方法, 该注解只能用于方法
•@Deprecated: 用于表示某个程序元素(类, 方法等)已过时
•@SuppressWarnings: 抑制编译器警告.
二,自定义 Annotation
1,方法:
定义Annotation 使用 @interface 关键字:(作用,原来写在配置文件中的信息,可以通过注解描述)
2,支持的类型:
•注解属性的类型只能是如下类型:
String类型 8大基本数据类型 Class类型 枚举类型 注解类型 以上类型的一维数组
代码(定义注解):
public @interface MyAnnotation {
//支持的可以配置的类型
String name() default "flx";//声明注解的属性,默认 "flx"
int age() default 35;
Gender gender() default Gender.MALE;
Class clazz() default String.class;//配置一个类
MyAnnotation2 my2() default @MyAnnotation2(name="fsq");//注解中的注解,实现一些嵌套配置
String [] args() default {"11","222"};
//还支持以上类型的一维数组
}
代码(使用注解):
@MyAnnotation(name="zxx",age=38,gender=Gender.FEMALE,clazz=String.class,my2=@MyAnnotation2(name="zc"),args={"111"})
public void test3(){
}
•有如果一个注解只有一个属性,并且这个属性的名称为value的话,那么使用注解时可以省略value=部分,如@MyAnnotation(“xxx"),直接赋值
三、JDK 的元 Annotation
元 Annotation指修饰Annotation的Annotation
JDK中定义了如下元Annotation:
@Retention: 只能用于修饰一个 Annotation 定义, 用于指定该 Annotation 可以保留的域, @Rentention 包含一个 RetentionPolicy 类型的成员变量, 通过这个变量指定域。
•RetentionPolicy.CLASS: 编译器将把注解记录在 class 文件中. 当运行 Java 程序时, JVM 不会保留注解. 这是默认值 •RetentionPolicy.RUNTIME:编译器将把注释记录在 class 文件中. 当运行 Java 程序时, JVM 会保留注解. 程序可以通过反射获取该注释 •RetentionPolicy.SOURCE: 编译器直接丢弃这种策略的注释
代码(声明运行时 注解):
@Retention(RetentionPolicy.RUNTIME)//加元注解,将注解声明为运行时注解
public @interface MyAnnotation {如果注解不加说明的话,注解是作用在class上的,但当虚拟机将class加载到内存之后,会抛弃这个注解
//支持的可以配置的类型
String name() default "flx";//声明注解的属性,默认 "flx"
int age() default 35;
Gender gender() default Gender.MALE;
Class clazz() default String.class;//配置一个类
MyAnnotation2 my2() default @MyAnnotation2(name="fsq");//注解中的注解,实现一些嵌套配置
String [] args() default {"11","222"};
//还支持以上类型的一维数组
}
@Target :指定注解用于修饰类的哪个成员. @Target 包含了一个名为 value,类型为ElementType的成员变量。
代码:
@Target({ElementType.METHOD,ElementType.FIELD})//如果没有声明,会作用于类的所有成员
public @interface MyAnnotation {如果注解不加说明的话,注解是作用在class上的,但当虚拟机将class加载到内存之后,会抛弃这个注解
//支持的可以配置的类型
String name() default "flx";//声明注解的属性,默认 "flx"
int age() default 35;
Gender gender() default Gender.MALE;
Class clazz() default String.class;//配置一个类
MyAnnotation2 my2() default @MyAnnotation2(name="fsq");//注解中的注解,实现一些嵌套配置
String [] args() default {"11","222"};
//还支持以上类型的一维数组
}
l@Documented: 用于指定被该元 Annotation 修饰的 Annotation 类将被 javadoc 工具提取成文档.
l@Inherited: 被它修饰的 Annotation 将具有继承性.如果某个类使用了被 @Inherited 修饰的 Annotation, 则其子类将自动具有该注解
代码:
@Inherited//使用MyAnnotation注解的类在被子类继承时,注解的信息也被继承
public @interface MyAnnotation {如果注解不加说明的话,注解是作用在class上的,但当虚拟机将class加载到内存之后,会抛弃这个注解
//支持的可以配置的类型
String name() default "flx";//声明注解的属性,默认 "flx"
int age() default 35;
Gender gender() default Gender.MALE;
Class clazz() default String.class;//配置一个类
MyAnnotation2 my2() default @MyAnnotation2(name="fsq");//注解中的注解,实现一些嵌套配置
String [] args() default {"11","222"};
//还支持以上类型的一维数组
}