第十六章--注解
注解
JDK5.0以上的版本引入了一项新特性:Annotation,中文翻译成注解,是用来为程序元素(类、方法、成员变量等)设置说明和解释的一种元数据,Java开发和部署工具可以读取这些注解,并以某种形式处理这些注解。
16.1 注解概述
ˉ 注解(annotation)是JDK 5.0以上版本新增加的功能。它可以添加到程序的任何元素(包声明、类型声明、构造方法、方法、成员变量等)上,用来设置一些说明和解释,Java开发和部署工具可以读取这些注释,并以某种形式处理这些注释。
ˉ 注解是在代码里做的特殊标记,这些标记可以在编译、类加载、运行时被读取,并执行相应的处理。
ˉ 通过使用注解,程序员可以在不改变原有逻辑的情况下,在源文件中嵌入一些补充的描述源代码的信息(这些信息被存储在注解的“name=value”键-值对中)。代码分析工具、开发和部署工具可以通过这些补充的、描述源代码的信息进行验证或者进行部署。
ˉ 注解类似于修饰符一样被使用,可以用于包、类、构造方法、方法、成员变量、参数、局部变量的声明。
需要注意的是,注解被用来为程序元素设置元数据,它不影响程序代码的执行,即无论增加、删除注解,程序的执行都不受任何影响。如果希望让程序中的注解起一定作用,只有通过配套的工具对注解中的元数据信息进行提取、访问,根据这些元数据增加额外功能和处理等。
16.2 JDK内置的基本注解类型
ˉ Java的注解采用“@”标记形式,后面跟上注解类型名称,如果注解需要数据,通过“name=value”向注解提供数据。
ˉ 注解类型和注解的区别:注解类型是某一类型注解的定义,类似于类。注解是某一注解类型的一个具体实例,类似于该类的实例。
ˉ 预定义了三个注解:
μ 重写Override:是一个限定重写方法的注解类型,用来指明被注解的方法必须是重写超类方法的方法,只能用于方法上。编译器在编译源代码时会检查用@Override标注的方法是否有重写父类的方法。

μ 警告Deprecated:用来标记已过时成员的注解类型,用来指明被注解的方法是一个过时的方法,不建议使用了。当编译调用到被标注为Deprecated的方法的类时,编译器就会产生警告。
μ 抑制警告SuppressWarnings:是抑制编译器警告的注解类型,用来指明被注解的方法、变量或类在编译时如果有警告信息,就阻止警告。
@SuppressWarnings(value={"unchecked", "deprecation"}),
16.3 自定义注解类型
ˉ Java中允许程序员自定义注解类型。注解类型的定义和接口类型的定义差不多,只是在interface前面多了一个“@”。
/** 自定义注解类型 */
public @interface MyAnnotation {
}
或者
/**带属性的注解类型*/
public @interface MyAnnotation{
String value(); //定义一个属性
}
ˉ 使用注解
/** 使用自定义注解类型:MyAnnotation */
class UserMyAnnotation{
@MyAnnotation("abc")
public void myMethod(){
System.out.println("使用自定义的注解");
}
}