一、注解:
它不是注释 注释是程序员写的,给程序员的
注解给程序看,用于描述程序如何运行及在什么阶段来运行。
注解现在在实际开发中,最大的功能是用于替换配置文件。
注解是jdk1.5的新特性
可以通过反射来让注解具有功能。
注解 @xxxx
2.1、自定义注解
1、JDK中的三个基本的注解:
a、@Override:检查子类确实是覆盖了父类的方法。
b、@Deprecated:说明已经过时了。
c、@SuppressWarnings({ "unused", "deprecation" }):抑制程序中的警告。unused警告的类型。{}数组。all抑制所有警告。
2.2、自定义注解的语法:(肉体)
研究一下注解的本质
声明一个注解 @interface 注解名{}
public @interface MyAnnotation{}
注解它的本质就是一个接口,这个接口需要继承 Annotation接口。
但我们自定义注解的时候不能直接这么写,下面这种形式是通过反编译注解类的class文件得到的。
public interface MyAnnotation extends java.lang.annotation.Annotation {
}
分析注解中的成员
注解本质上就是接口,接口中可以有属性方法
属性 : 例:int age();
关于注解的属性类型可以有哪些?
1.基本类型
2.String
3.枚举类型
4.注解类型
5.Class类型
6.以上类型的一维数组类型
l 角色1:注解的定义者
l 角色2:注解的使用者
package com.itcst.stuedy.demo1;
public class Test {
/**
* package com.itcst.stuedy.demo1;
*
* public @interface MyAnnon { int num(); String name(); Class<?> c();
* String[]ss(); } MyAnnon定义方式
*/
@MyAnnon(name = "tom", num = 10, c = Person.class, ss = { "aa", "bb" })
public void testq() {
}
/**
* MyAnnon1定义方式 package com.itcst.stuedy.demo1;
*
* public @interface MyAnnon1 {
*
* String [] value();
*
* }
*
*/
// @MyAnnon1(value = {"a","b","c"}) //value 第一种方式
// @MyAnnon1({"a","b","c"})//第二种方式
@MyAnnon1("a") // 数组只有一个值时可以这么些
public void test1() {
}
//@MyAnnon2
@MyAnnon2(name="bood")//如果名称为value 的话,可以直接写成@MyAnnon2("bood")
public void test2(){
}
}
注解:就是在你的程序代码中的某个位置加了一个标记而已。
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、反射注解中的属性
2.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:作用,说明该注解可以被继承下去。
二、慕课网截图