1.1 注解的概述:
1.1.1 注解的概念:
- 注解是JDK1.5的新特性。
- 注解相当于一种标记,是类的组成部分,可以给类携带一些额外的信息。
- 标记(注解)可以加在包、类、成员变量、方法、方法参数以及局部变量上。
- 注解是给编译器或JVM看的,编译器或JVM可以根据注解来完成对应的功能。
注解(Annotation)相当于一种标记,在程序中加入注解就等于为程序打上某种标记,以后,javac编译器、开
发工具和其他程序可以通过反射来了解你的类及各种元素上有无何种 标记,看你的程序有什么标记,就去
干相应的事,标记可以加在包、类,属性、方法,方法的参数以及局部变量上。
- 在使用框架的时候,我们需要做一些配置信息,那么在JDK1.5之前,这些配置信息需要写在一个文件里面。那么这时候就存在一个问题,当我们有什么类的时候,每一个类都需要配置一次(配置文件),维护起来就很困难。在JDK1.5之后,我们可以通过注解来解决这个问题,将注解写在这些类上面,同样起到了配置的效果。
1.1.2 注解的作用:(生成帮助文档/编译检查/框架的配置(框架=代码+配置) )
注解的作用就是给程序带入参数。
- 1.生成帮助文档:@author和@verson
- @author:用来标识作者姓名。
- @version:用来标识对象的版本号,适用范围:文件、类、方法。
- 使用@author和@Version注解就是告诉javadoc工具在生成帮助文档时把作者姓名和版本号也标记在文档中。
- 2.编译检查:@Override
- 用来修饰方法声明。
- 用来告诉编译器该方法时重写父类中的方法,如果父类不存在该方法,则编译失败。如下图:
- 3.框架的配置(框架=代码+配置)
1.2 自定义注解
1.2.1 定义格式:
/* 注解的定义格式: public @interface 注解名{ } */ //如定义一个Student的注解 public @interface Student { }
1.2.2 注解的属性:
注解的定义格式: @interface 注解名{ }
- 属性的作用:可以让使用者在使用注解的时候传递参数,增强注解功能。
- 属性的定义格式:
- 格式1:数据类型 属性名();
- 格式2:数据类型 属性名() default 默认值;
- 属性适用的数据类型:
- 八种基本数据类型:byte,char,boolean,int,long,double,float,short
- String,Class,注解,枚举类
- 以上数据类型的数组形式
public @interface Student {
//姓名(属性)
String name();
//年龄
int age() default 18;
//爱好
String [] hobbies();
}
1.2.3 使用注解:
1.定义在成员方法上使用Book注解
- 使用注意事项:
- 如果属性有默认值,则使用注解时候,这个属性可以不用赋值。
- 如果属性没有默认值,那么在使用注解时一定要给属性赋值。