注解:说明程序的。给计算机看java
注释:用文字描述程序,给程序员看的程序员
定义:注解,也叫元数据,一种代码级别的说明。他是JDK1.5及以后版本引入的一个特征,与类、接口、枚举是在同一层次,他能够声明在包、类数组
、字段、方法、局部变量、方法参数等的前面,用来对这些元素进行说明,注释ide
做用分类:一、编写文档,经过代码里面标识的注解生产文档.net
二、代码分析,经过代码里面标识的注解对代码进行分析继承
三、编译检查,经过代码里标识的注解让编译器可以实现基本的编译检查接口
JDK中预约义的一些注解:文档
@Override,检测被该注释标注的方法是不是继承父类(接口)的get
@Deprecated,该注释标注的内容,表示已过期编译器
@SuppressWarnings,压制警告
自定义注解:
格式:一、元注解:用于描述注解的注解
二、public @interface 注解名称{
属性;
}
本质:public interface 注解名称 extends java.lang.annotation.Annotation{}
就是一个接口,该接口默认继承Annotation接口
属性:接口中的抽象方法
要求:一、属性的返回值类型必须为基本数据类型,String,枚举,注解,以上类型的数组
二、定义了属性在使用时要给属性赋值。
若是定义属性时使用default关键字给属性默认初始化值,则使用注解时,能够不进行属性的赋值
若是只有一个属性须要赋值,而且属性的名称是value,则value能够省略,直接定义值便可
元注解:
一、@Target:描述注解可以做用的位置
ElementType取值:一、TYPE:能够做用于类上
二、METHOD:能够做用于方法上
三、FIELD:能够做用于成员变量上
二、@Retention:描述注解被保留的阶段
RetentionPolicy取值:RUNTIME:当前被描述的注解,会保留到class字节码文件中,并被JVM读取到
三、@Documented:描述注解是否被抽取到API文档中
四、@Inherited:描述注解是否被子类继承
在程序中使用注解:
@Target(ElementType.TYPE) @Documented @Retention(RetentionPolicy.RUNTIME) public @ interface MyAnno { String value(); }
public class Demo { public static void main(String[] args) throws Exception{ Class personClass = Person.class; MyAnno anno = (MyAnno) personClass.getAnnotation(MyAnno.class); System.out.println(anno.value()); } }