注解
- java5开始支持,对程序元素(类.方法.字段.构造器)进行描述
- 一个特殊的接口,自定义的注解都是继承自java.lang.annotation.Annotation接口
- 注解的定义方式:@interface 注解的名称
如同如同枚举是一个特殊的类,默认继承java.lang.Enum
JDK中内置的注解
1: @Override 限定重写父类的方法 2: @Deprecated 标记已过时的成员,不推荐使用 3: @SuppressWarnings (all)--抑制所有类型的警告 4: @SafeVarargs 抑制堆污染警告 当一个方法中出现泛型和可变参数的时候,就可能出现该警告
使用注解的位置和注解的参数传递为什么不同
元注解
元注解: 描述注解的注解.
@Retention :表示注解可以保存到那个时期(SIURCE,CLASS,RUNTIME), 保存的值在RetentionPolicy枚举类中, 因为要使用反射来赋予注解特殊的功能,所以需要保存到RUNTIME时期; @Target:表示注解可以贴到那些位置; @Documented:表示使用@Documented标注的标签会保存到API文档中; @Inherited :表示使用@Inherited标注的标签可以被子类继承到;
自定义注解
使用 @interface 定义注解
@Retention(RetentionPolicy.RUNTIME) // 保存时期 @Target({ElementType.TYPE,ElementType.METHOD})//贴到类上,方法上 public @interface 注解名{ //注解中定义元素,和接口中的方法一样 String name() default "will"; int age() default 10; } //注解支持的数据类型 基本数据类型 String Class 注解,枚举,数组 //在给注解传递值的时候不想指定元素名称
常用操作:
getAnnotation(注解.class) ;获取指定注解 isAnnotationPresent(注解.class):判断程序上是否有注解 getDeclaredAnnotation();返回所有注解
如果在给注解传值得时候不想指定元素名称,可以将元素名定义为value