注解:
它不是注释 注释是程序员写的,给程序员的
注解给程序看,用于描述程序如何运行及在什么阶段来运行。
注解现在在实际开发中,最大的功能是用于替换配置文件。
注解是jdk1.5的新特性
可以通过反射来让注解具有功能。
注解 @xxxx
2.1、自定义注解
1、JDK中的三个基本的注解:
a、@Override:检查子类确实是覆盖了父类的方法。
b、@Deprecated:说明已经过时了。
c、@SuppressWarnings({ "unused", "deprecation" }):抑制程序中的警告。unused警告的类型。{}数组。all抑制所有警告。
2、自定义注解的语法:(肉体)
研究一下注解的本质
声明一个注解 @interface 注解名{}
public@interface MyAnnotation{}
注解它的本质就是一个接口,这个接口需要继承 Annotation接口。
publicinterface MyAnnotation extends java.lang.annotation.Annotation {
}
分析注解中的成员
注解本质上就是接口,接口中可以有属性方法
属性 : 例:int age();
关于注解的属性类型可以有哪些?
1.基本类型
2.String
3.枚举类型
4.注解类型
5.Class类型
6.以上类型的一维数组类型
l 角色1:注解的定义者
l 角色2:注解的使用者
注解:就是在你的程序代码中的某个位置加了一个标记而已。
3、注解的反射:(灵魂)
模拟Junit的@Test
a、反射注解类
java.lang.reflect.AnnotatedElement:
l <T extends Annotation> T getAnnotation(Class<T>annotationType):得到指定类型的注解引用。没有返回null。
l Annotation[] getAnnotations():得到所有的注解,包含从父类继承下来的。
l Annotation[] getDeclaredAnnotations():得到自己身上的注解。
l boolean isAnnotationPresent(Class<? extends Annotation>annotationType):判断指定的注解有没有。
Class、Method、Field、Constructor等实现了AnnotatedElement接口.
如果:Class.isAnnotationPresent(MyTest.class):判断类上面有没有@MyTest注解;
Method.isAnnotationPresent(MyTest.class):判断方法上面有没有@MyTest注解。
b、反射注解中的属性
4、元注解
a、自定义的注解的存活范围(生命周期):默认是CLASS。
什么是元注解:
只能用在注解上的注解叫做元注解。(即:用于修饰注解的注解)
l @Retention:作用。改变自定义的注解的存活范围。
RetentionPolicy:
SOURCE
CLASS
RUNTIME
l @Target:作用,指定该注解能用在什么地方。
ElementType:
TYPE:
METHOD:
FIELD:
ANNOTATION_TYPE
@Documented:作用,使用了@MyTest的注解的类,如果@MyTest注解上面有@Documented注解,那么使用了@MyTest的注解的类的API文档中会出现@MyTest的身影。
@Inherited:作用,说明该注解可以被继承下去。
Servlet3.0:
Tomcat7+;JDK6.0+;
Servlet3.0:web.xml已经不是必须的了。替代它的就是注解。