格式
public @interface 注解名称{}。通俗讲,注释是给程序员看的描述信息,注解是给计算机看的附加信息
本质
public interface 注解名称 extends java.lang.annotation.Annotation{},同上述红色字体
注解本质是一个接口,继承Annotation接口。假设,一个类添加了注解,在程序运行时,
1、首先获取该类的字节码文件。
2、根据注解,内存中会自动生成一个该注解接口的实现对象。
3、通过 getAnnotation( ) 方法获取该对象。
4、通过注解对象调用注解方法。
代码解释
@注解名称( 注解参数1, 注解参数2 )
public class Test{
// 1、解析注解
// 1、1 获取该类的字节码文件对象
Class<Test> testClass = Test.class;
// 2、获取上面的注解对象
// 本质上,在内存中生成一个该注解接口的子类实现对象
/*
public class 注解名称Impl implements 注解名称{
public String 注解方法1(){
return "注解参数1";
}
public String 注解方法2(){
return "注解参数2";
}
}
*/
注解名称 an = testClass.getAnnotation(注解名称.class);
// 3、调用注解中的方法获取属性值
an.注解方法();
}
最终解释
@注解名称( 注解参数1, 注解参数2 )
根据以上注解格式
1、注解是一个接口
2、程序执行时,会自动在内存中生成一个注解接口的实现类注解名称Impl
3、注解名称Impl会根据以上注解格式 || @注解名称( 注解参数1, 注解参数2 ) || 通过传入参数的构造方法的方式产生一个 注解名称Impl 的实例对象
4、根据该实例对象使用注解定义的方法